清明上河图哪个朝代,的得地的用法,惊变28周qvod
逻辑处理上分成了多个模块,为了提高效率,前一个模块处理完调用后一个模块操作时使用多线程
我这里遇到的情形是前面取数据后面存到mysql,发现单线程效率很低,改为取数据后开线程存到mysql
开启线程之后性能提升一倍,同时用信号量做线程同步,控制数据库同时连接数
这里只是简单的一个demo,主要是开线程的处理方式,在自己类里面的函数中开启线程,并用自己类的成员函数做线程运行函数。
#coding=utf-8 import threading class test: __init = 1 def __init__(self): self.__sem = threading.semaphore(value=5)#初始化信号量,最大并发数 return def handle(self, data): #开启线程,传入参数 _thread = threading.thread(target=self.__run, args=(data,)) _thread.setdaemon(true) _thread.start()#启动线程 return def __run(self, data): self.__sem.acquire()#信号量减1 self.__init +=data print(self.__init) self.__sem.release()#信号量加1 return if __name__=="__main__": test = test() test.handle(1) print("end")
以上这篇python开启线程,在函数中开线程的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持移动技术网。
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
Python爬虫:Request Payload和Form Data的简单区别说明
浅谈Python中threading join和setDaemon用法及区别说明
Python3-异步进程回调函数(callback())介绍
python继承threading.Thread实现有返回值的子类实例
Python中使用threading.Event协调线程的运行详解
网友评论