day19-多线程基础
一、多线程理论
1. 什么是进程
- 指系统中正在运行的一个程序
- 特点:每个进程是独立的,每个进程均运行在其专用且受保护的内存空间
2. 什么是线程
- 一个进程要想执行任务,必须得有线程(每个进程至少要有一条线程)
- 一个进程的所有任务都在线程中执行
- 线程的串行:
- 一个线程中任务的执行是串行的
- 同一时间一个线程只能执行一个任务
3. 进程和线程的比较
- 1)线程是cpu调用的最小单位
- 2)进程是cpu分配资源和调度的单位
- 3)一个程序可以对应多个进程,一个进程中可以有多个线程,但至少要有有一个线程
- 4)同一进程内的线程共享进程的资源
4. 什么是多线程
- 定义:一个进程中可以开启多条线程,每条线程可以并行执行不同的任务
- 作用:多线程技术可以提高程序的执行效率
- 原理:
- 同一时间,cpu只能处理一条线程,只有一条线程在工作
- 多线程并发执行,其实就是cpu快速的在多条线程之间的调度
- 如果cpu调度线程时间足够快,就造成了多线程并发执行的假象
二、多线程技术
1. 主线程和子线程
- 默认情况下,进程有一个线程,这个线程叫主线程。(主线程是自动创建的)
- 默认情况下所有的代码都是在主线程中执行的
- 程序员通过代码创建的线程都叫子线程。
2. 创建子线程
- python内置的threading模块中提供了和线程操作相关的类和方法
- threading模块中有个Thread类,这个类或者这个的子类的对象就是线程对象
- 需要子线程的时候就创建Thread类的对象
- 1)创建线程对象
- 语法:
Thread(target=函数, args=实参列表) - 返回子线程对象
- 说明:target-必须要赋一个函数,这个函数会在子线程中调用
- args-赋一个元组,元组中的元素就是调用target函数的时候需要传的参数
- 语法:
- 2)让子线程开始执行
- 线程对象.start()-在子线程中去调用target对应的download,并且将args中的值作为实参
- 3)程序的结束(进程的结束)
- 一个进程是否结束,看这个进程中是否每个线程都结束
- 线程结束:任务执行完成自然死亡、遇到exit()函数、发生异常
- 程序出现异常只会影响一个线程,线程中遇到exit(),线程直接结束
3. 通过创建Thread类的子类对象来创建子线程
- 1)声明一个类继承Thread
- 2)实现run方法,这个方法中的代码就是会在子线程中执行的代码
- 3)创建子类的线程对象
- 4)通过start去执行子线程中的任务
4. join()方法
线程对象.join()
其他对象
说明:这儿的其他代码会等到线程对象结束后才会执行
5. 多线程数据安全问题
- 通过加锁来解决数据安全问题
- 1)保证一个数据对应一把锁:创建锁的对象
- 2)在使用数据之前,加锁:锁对象.acquire()
- 3)数据使用完后,释放锁:锁对象.release()