一、概念
多线程(multithreading)是指在软件或者硬件上实现多个线程并发执行的技术,优点如下:
1、多线程可以把占据较长时间的任务放到后台处理
2、多线程可以使程序的运行速度加快
3、某些等待的任务实现(如用户输入、文件读写、网络收发数据等),多线程的使用可以释放一些珍贵的如内存占用资源等
每个独立的线程均有一个程序运行的入口、顺序执行序列和程序的出口。但线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。
每个线程都有其本身的一组CPU寄存器,称为线程的上下文,该上下文反映了线程上次运行该线程的CPU寄存器的状态。
指令指针和堆栈指针寄存器是线程上下文中两个最重要的寄存器,线程总是在进程得到上下文中运行的,这些地址都用于标志拥有线程的进程地址空间中的内存。
线程可以被抢占(即中断),也可以当在其他线程正在运行时,线程暂时搁置(也称为睡眠),这就是线程的退让。
线程分为内核线程和用户线程,内核线程指由操作系统内核创建和撤销的线程,用户线程指不需要内核支持而在用户程序中创建和撤销的线程
Python3 线程中常用的两个模块为“_thread”和“threading”,推荐使用threading。Python3已废弃“thread”模块,改为“_thread”替代
二、线程创建
Python使用线程通常有两种方式:函数或者用类来包装线程对象
2.1、_thread模块创建线程
函数式:
调用_thread模块的start_new_thread()创建线程,具体语法为:
_thread.start_new_thread(function , args , kwargs)
参数说明:
function:线程函数
args:传递给线程函数的参数,必须是tuple(元组)类型
kwargs:可选参数
"""
使用_thread创建线程
"""
import _thread
import time
# 定义线程函数
def print_time(ThreadName , delay):
# 计数器初始值设置为0
count = 0
# 打印3次
while count < 3:
# 延时delay秒
time.sleep(delay)
# time.time()返回当前时间的时间戳;time.ctime()把时间戳(按秒计算的浮点数)转化为time.asctime()形式
print("%s:%s" % (ThreadName , time.ctime(time.time())))
count += 1
# 创建线程
try:
_thread.start_new_thread(print_time , ("Thread_1" , 3 ,))
_thread.start_new_thread(print_time , ("Thread_2" , 5 ,))
except:
print("线程创建失败~~~")
# 无限循环
while 1:
pass
运行结果:
Thread_1:Sun Aug 9 21:47:52 2020
Thread_2:Sun Aug 9 21:47:54 2020
Thread_1:Sun Aug 9 21:47:55 2020
Thread_1:Sun Aug 9 21:47:58 2020
Thread_2:Sun Aug 9 21:47:59 2020
Thread_2:Sun Aug 9 21:48:04 2020
三、线程模块
Python3提供了“_thread”和“threading”两个标准库实现对线程的支持,但“_thread”提供了低级别的、原始的线程以及一个简单的锁,“threading”相比“_thread”功能丰富得多,其提供如下方法:
1、threading.currentThread():返回当前的线程变量
2、threading.enumerate():返回一个包含正在运行的线程的list。正在运行指线程启动后、结束前,不包括启动前和终止后的线程
3、threading.activeCount():返回正在运行的线程数量,与len(threading.enumerate())有相同的结果
除以上提供的方法外,线程模块也提供了Thread类来处理线程,Thread类提供了以下方法:
1、run():用以表示线程活动的方法
2、start():启动线程活动
3、join(time):等待至线程中止。其阻塞调用线程直至线程的join() 方法被调用中止-正常退出或者抛出未处理的异常-或者是可选的超时发生
4、isAlive():返回线程是否活动的
5、getName():返回线程名
6、setName():设置线程名
四、threading 模块创建线程
"""
使用 threading 创建线程
从 threading.Thread 继承创建一个新的子类,实例化后调用 start() 方法启动新线程
"""
import threading , time