python多线程之threading模块

话不多说,直接开始吧????

调入模块:

import threading

threading的几个方法

创建线程对象:

t1 = threading.Thread(target=output, args=("小明",))

target : 线程所要执行的函数名称
args :函数的参数

启动线程:

t1.start()

将线程设置为守护线程:

t1.setDaemon(True)

设置主线程等待子线程结束:

t1.join()

下面通过不同的实例来展示一下不同方法的作用

1.创建线程(非守护线程)

import threadingimport timeprint(time.asctime(time.localtime(time.time()))) #记录开始时间def output(hh):  #所要执行的函数print("nihao %s" % hh)time.sleep(2)print(time.asctime(time.localtime(time.time())))  #记录每个子线程结束的时间def main():  #创建6个子线程t1 = threading.Thread(target=output, args=("小明",))t2 = threading.Thread(target=output, args=("小红",))t3 = threading.Thread(target=output, args=("小刚",))t4 = threading.Thread(target=output, args=("小文",))t5 = threading.Thread(target=output, args=("小康",))t6 = threading.Thread(target=output, args=("小莉",))t1.start()t2.start()t3.start()t4.start()t5.start()t6.start()print("我要结束了哦")if __name__ == '__main__':main()

执行结果:

Fri Jun 12 17:24:56 2020nihao 小明
nihao 小红
nihao 小刚
nihao 小文
nihao 小康
nihao 小莉我要结束了哦

Fri Jun 12 17:24:58 2020Fri Jun 12 17:24:58 2020Fri Jun 12 17:24:58 2020Fri Jun 12 17:24:58 2020Fri Jun 12 17:24:58 2020Fri Jun 12 17:24:58 2020

这里可以看到,各个子线程执行完是在同一时间,从开始到结束用了2秒钟。输出结果顺序混乱是多线程的正常现象)

要注意的是,主线程运行完之后并没有直接结束,而是等待各个子线程结束之后才结束,这是非守护线程的效果

2.使用 .setDaemon(True) 创建守护线程

import threadingimport timeprint(time.asctime(time.localtime(time.time())))  #记录开始时间def output(hh):  #所要执行的函数print("nihao %s" % hh)time.sleep(2)print(time.asctime(time.localtime(time.time())))  #记录每个子线程结束的时间def main():  #创建6个子线程t1 = threading.Thread(target=output, args=("小明",))t2 = threading.Thread(target=output, args=("小红",))t3 = threading.Thread(target=output, args=("小刚",))t4 = threading.Thread(target=output, args=("小文",))t5 = threading.Thread(target=output, args=("小康",))t6 = threading.Thread(target=output, args=("小莉",))t1.setDaemon(True)t2.setDaemon(True)   #设置为守护进程t3.setDaemon(True)t4.setDaemon(True)t5.setDaemon(True)t6.setDaemon(True)t1.start()t2.start()t3.start()t4.start()t5.start()t6.start()print("我要结束了哦")if __name__ == '__main__':main()

执行结果:

Fri Jun 12 17:38:31 2020nihao 小明
nihao 小红
nihao 小刚
nihao 小文
nihao 小康
nihao 小莉我要结束了哦

这里可以看到,当所有子线程都设置为守护线程时,主线程运行完之后就直接结束了,而没有等待子线程结束,导致子线程没有运行完。

3.使用 .join() 方法使主线程等待子线程结束

import threadingimport timeprint(time.asctime(time.localtime(time.time())))  #记录开始时间def output(hh):print("nihao %s" % hh)time.sleep(2)print(time.asctime(time.localtime(time.time())))  #记录每个子线程结束的时间def main():  #创建6个子线程t1 = threading.Thread(target=output, args=("小明",))t2 = threading.Thread(target=output, args=("小红",))t3 = threading.Thread(target=output, args=("小刚",))t4 = threading.Thread(target=output, args=("小文",))t5 = threading.Thread(target=output, args=("小康",))t6 = threading.Thread(target=output, args=("小莉",))t1.setDaemon(True) 
    t2.setDaemon(True)  
    t3.setDaemon(True)t4.setDaemon(True)t5.setDaemon(True)t6.setDaemon(True)t1.start()t2.start()t3.start()t4.start()t5.start()t6.start()t1.join()t2.join()t3.join()t4.join()t5.join()t6.join()print("我要结束了哦")if __name__ == '__main__':main()

执行结果:

Fri Jun 12 18:00:39 2020nihao 小明
nihao 小红
nihao 小刚
nihao 小文
nihao 小康
nihao 小莉
Fri Jun 12 18:00:41 2020Fri Jun 12 18:00:41 2020Fri Jun 12 18:00:41 2020Fri Jun 12 18:00:41 2020Fri Jun 12 18:00:41 2020Fri Jun 12 18:00:41 2020我要结束了哦

我们可以看到,当设置了主线程等待子线程结束,子线程都运行完之后主线程才运行完。

使用.join() 方法和直接创建非守护进程的区别是:

使用 .join() 方法,主线程会等待子线程都运行完之后才执行后面的语句,所以主线程结束时,子线程肯定是已经运行完的。

直接创建非守护进程,主线程和子线程会同时运行,如果主线程运行完早于子线程,这时主线程会等待子线程运行完之后才结束。

4.批量创建子线程

import threadingimport timeprint(time.asctime(time.localtime(time.time())))  #记录开始时间def output(hh):print("nihao %s" % hh)time.sleep(2)print(time.asctime(time.localtime(time.time())))  #记录每个子线程结束的时间if __name__ == '__main__':thread_list = []for i in range(10):t = threading.Thread(target=output,args=("帅哥",))t.start()thread_list.append(t)for thread in thread_list:thread.join()

执行结果:

Fri Jun 12 19:40:57 2020nihao 帅哥
nihao 帅哥
nihao 帅哥
nihao 帅哥
nihao 帅哥
nihao 帅哥
nihao 帅哥
nihao 帅哥
nihao 帅哥
nihao 帅哥
Fri Jun 12 19:40:59 2020Fri Jun 12 19:40:59 2020Fri Jun 12 19:40:59 2020Fri Jun 12 19:40:59 2020Fri Jun 12 19:40:59 2020Fri Jun 12 19:40:59 2020Fri Jun 12 19:40:59 2020Fri Jun 12 19:40:59 2020Fri Jun 12 19:40:59 2020Fri Jun 12 19:40:59 2020

所有子线程都是在同一时刻结束。

讲解的不正确的地方,还请大神指出,我们共同进步。????

相关文章

功能概要:(目前已实现功能)公共展示部分:1.网站首页展示...
大体上把Python中的数据类型分为如下几类: Number(数字) ...
开发之前第一步,就是构造整个的项目结构。这就好比作一幅画...
源码编译方式安装Apache首先下载Apache源码压缩包,地址为ht...
前面说完了此项目的创建及数据模型设计的过程。如果未看过,...
python中常用的写爬虫的库有urllib2、requests,对于大多数比...