1.什么是进程
一个正在运行的应用程序就是一个进程.系统会给每一个进程分配一个独立的内存区域,用来保存程序运行过程中产生的数据,当进程结束的时候,这个内存区域会自动销毁
2.什么是线程
进程想要执行任务,就必须要有线程.每个进程都默认有一个线程,这个线程叫主线程;其他的线程叫子线程,程序都是默认在主线程中执行的
一个线程中执行多个任务,任务是串行执行的(一个一个地执行)
一个进程中如果有多个线程,多线程执行不同任务的时候是并行(同时执行)
3.python中怎么使用多线程
python通过内置的threading模块来提供多线程相关技术;
其中有一个Thread类,这个类的对象就是线程对象
创建线程的方法
1.直接创建线程类的对象
语法:
线程对象 = Thread(target=函数,args =参数) - 创建一个线程对象,并且返回
说明:
函数 - function类型的变量;这个函数的函数体会在子线程中执行
参数 - 元组;参数会给target对应的函数(单个元组用括号括起来,还要有逗号)
让子线程开始执行任务
线程对象.start() - 开始执行子线程中的任务
补充:某个线程出现异常,是线程直接结束;进程不一定结束,所有的线程结束,进程才会结束
2.创建线程子类
- 声明一个类继承自Thread
- 重写run方法,这个方法中的任务就是需要在子线程中执行的任务
- 创建当前类的对象,就是线程对象
- 启动子线程
class DownloadThread(Thread):
def __init__(self, film):
super().__init__()
self.film = film
def run(self):
print('%s开始下载...' % self.film)
time1 = randint(3, 10)
time.sleep(time1)
print('%s下载结束,总耗时%d秒' % (self.film, time1))
创建线程对象
t1 = DownloadThread('霸王别姬')
t2 = DownloadThread('海贼王')
线程对象 = 类名(参数) - 类名是自己定义的继承了Thread类的这个类的名字,参数是类的对象属性,所以需要传参
启动线程
- 线程对象调用start会自动在子线程中取调用run方法
- 直接用线程对象调用run方法,run方法会在主线程中执行
start = time.time() # 此时的时间
t1.start()
t2.start()
# 在子线程t1和t2中执行的
# 如果t1.run(),那么run方法会在主线程中执行
补充:join的用法
线程对象.join() -- 程序执行到这个地方会停下来(线程阻塞),直到线程对象中的任务执行完后才执行后面的语句
t1.join()
t2.join()
# print('t1结束')
end = time.time() #此时的时间
print('总时间: ', end - start) # 总时间 = 结束时间减去开始时间