CPU
调度的最小单元CPU
、内存等)的最小单元import time
def work_1():
print('任务1...')
time.sleep(2)
def work_2():
print('任务2...')
time.sleep(2)
start = time.time()
work_1()
work_2()
end = time.time()
print(f'总共用时: {end - start} s')
任务1...
任务2...
总共用时: 4.020084857940674 s
work_2()
需要等待work_1()
运行结束后才能运行import time
import threading
def work_1():
print('任务1...')
time.sleep(2)
def work_2():
print('任务2...')
time.sleep(2)
# 通过 Thread 类创建线程对象, 并使用 target 绑定线程对象要运行的任务
t1 = threading.Thread(target=work_1)
t2 = threading.Thread(target=work_2)
# 运行线程
start = time.time()
t1.start()
t2.start()
t1.join()
t2.join()
end = time.time()
print(f'总共用时: {end - start} s')
任务1...
任务2...
总共用时: 2.0165793895721436 s
可以看到整个程序用时
2
2
2秒,work_1()
和work_2
并发运行
下面的示例可以看到CPU
调度线程时的“随机性”
import time
import threading
def work_1():
for i in range(5):
print('任务1...')
time.sleep(2)
def work_2():
for i in range(5):
print('任务2...')
time.sleep(2)
t1 = threading.Thread(target=work_1)
t2 = threading.Thread(target=work_2)
t1.start()
t2.start()
任务1...
任务2...
任务2...任务1...
任务1...任务2...
任务2...
任务1...
任务2...
任务1...
CPU
的调度算法决定的Python
程序是如何被运行的
Python
文件被解释器运行时会在操作系统中创建一个进程t = threading.Thread()
时会创建一个新的线程,称为子线程CPU
进行调度,并发地运行,具体调度哪个线程由操作系统的调度算法决定thread_object.start()
t = threading.Thread()
只是创建了一个线程,并不会执行线程代码
t.start()
使线程t
达到就绪态,等待CPU
进行调度,具体何时调度由CPU
决定
以上面的并发任务的代码为例,先注释掉t1.start()
和t2.start()
import time
import threading
def work_1():
print('任务1...')
time.sleep(2)
def work_2():
print('任务2...')
time.sleep(2)
# 通过 Thread 类创建线程对象, 并使用 target 绑定线程对象要运行的任务
t1 = threading.Thread(target=work_1)
t2 = threading.Thread(target=work_2)
# 运行线程
start = time.time()
t1.start()
t2.start()
# t1.join()
# t2.join()
end = time.time()
print(f'总共用时: {end - start} s')
任务1...
任务2...
总共用时: 0.0009987354278564453 s
end = time.time()
时,此时end
记录的时间是主线程运行到这行代码的时间print(f'总共用时: {end - start} s')
,输出时间0.0009987354278564453 s
,此时执行到了文件末尾没有其他代码,主线程会等待子线程运行结束后再退出thread_object.join()
t.join()
使主线程等待子线程,子线程任务执行结束后主线程再继续向下执行t1.start()
和t2.start()
import time
import threading
def work_1():
print('任务1...')
time.sleep(2)
def work_2():
print('任务2...')
time.sleep(2)
# 通过 Thread 类创建线程对象, 并使用 target 绑定线程对象要运行的任务
t1 = threading.Thread(target=work_1)
t2 = threading.Thread(target=work_2)
# 运行线程
start = time.time()
t1.start()
t2.start()
t1.join()
t2.join()
end = time.time()
print(f'总共用时: {end - start} s')
任务1...
任务2...
总共用时: 2.008962392807007 s
thread_object.setDaemon()
import time
import threading
def work():
for i in range(5):
print(i)
time.sleep(1)
t = threading.Thread(target=work)
# t.setDaemon(True)
t.start()
print('主线程即将退出...')
0
主线程即将退出...
1
2
3
4
import time
import threading
def work():
for i in range(5):
print(i)
time.sleep(1)
t = threading.Thread(target=work)
t.setDaemon(True)
t.start()
print('主线程即将退出...')
0
主线程即将退出...
thread_object.current_thread()
import threading
def work():
name = threading.current_thread().name # getName()
print(name)
for i in range(5):
t = threading.Thread(target=work)
t.name = f'线程-{i}' # setName(f'线程-{i}')
t.start()