Day18 线程

多线程

1、进程

指系统中正在运行的一个引用程序叫进程

每个进程之间是独立的,每个进程均运行在其专用且受保护的内存空间内。

2、线程

1个进程要想执行任务,必须得有线程(每1个进程至少要有1条线程)

一个进程(程序)的所有任务都在线程中执行的。

线程的特点:

一个线程中任务的执行是串行的。

如果要在一个线程中执行多个任务,那么只能一个一个的按顺序执行这些任务

线程是CPU地哦啊与的最新单位

进程是CPU分配资源和调度的单位

一个程序可以对应多个进程,一个进程中

3、多线程

1个进程中可以开启多条线程,每条线程可以并行(同时)执行不同的任务

多线程的原理

同一时间,CPU只能处理1条线程,只有1条线程在工作(执行)

多线程并发执行,其实是CPU快速的在多线程直接调度(切换)

如果CPU调度线程的时间足够快,就造成了多线程并发执行的假象。

import threading
import time
def download(file):
    print('%s开始下载' % file, datetime.now())
    # sleep(时间)  - 程序执行到这个位置等待指定的时候再接着往后面执行
    time.sleep(10)
    print('%s下载结束' % file, datetime.now())
    
t1 = threading.Thread(target=download, args=('枪王之王.mp4',))
# 开始执行t1对应的子线程中的任务(实质就是在子线程中调用target对应的函数)
t1.start()

说明:

Thread(target,args) - 创建子线程对象
说明:
target - Function,需要传一个函数(这个函数中的内容会在子线程中执行)
args - 元祖,target对应的函数的参数
当通过创建好的子线程对象调用start方法的时候,会自动在子线程中调用target对应的函数, 并且将args中值作为实参

线程对象调用join方法,会导致join后的代码会在线程中的任务结束后才执行
用法:线程1里面新建一个线程2,线程2执行完,线程1收到反馈。

你可能感兴趣的:(Day18 线程)