python中使用多线程处理程序,会比一步步的处理节约很多时间,而且通过创建并继承Python的Thread类,重写run()方法,通过自定义的线程类来创建线程,本文介绍python多线程Thread类定义和如何自定义线程类的过程。
一、Thread类定义
threading.Thread(self,group=None,target=None,name=None,agrs=(),kwargs=None,*,daemon=None)
参数group是预留的,用于将来扩展;
参数target是一个可调用对象,在线程启动后执行;
参数name是线程的名字。默认值为“Thread-N“,N是一个数字;
参数args和kwargs分别表示调用target时的参数列表和关键字参数。
二、自定义线程类
1、创建一个类,并继承Python的Thread类,且重写run()方法实现具体的执行顺序由自己来定义。
fromthreadingimportThread importtime #创建一个类,并继承Python的Thread类,且重写run()方法实现具体的执行顺序由自己来定义 classMyThread(Thread): '''time.sleep代表等待10秒后才执行''' defrun(self): time.sleep(2) print("我是线程类...") '''下面这一段是从源码Thread类中的run方法复制过来的,当然 没有也许,因为继承了Thread,就会去父类里面找,我这里只是测试用''' try: ifself._target: self._target(*self._args,**self._kwargs) finally: #Avoidarefcycleifthethreadisrunningafunctionwith #anargumentthathasamemberthatpointstothethread. delself._target,self._args,self._kwargs
2、定义一个函数
defBar(): print("Bar...")
3、通过自定义的线程类来创建线程,并且关联函数Bar,最后执行这个线程。
t1=MyThread(target=Bar) t1.start() print("守护线程执行结束...")
需要注意:
自定义线程不能指定target,因为,自定义线程里面的任务统一都在run方法里面;
启动线程统一调用start方法,不要直接调用run方法,因为这样不是使用子线程去执行任务。
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论(0)