多任务
有多个任务,比如打饭只有一个窗口,人多就会很慢,如果食堂有多个窗口,也就是多任务。
import time
def buy_food(num):
print('学生%s买饭' % num)
time.sleep(2)
if __name__ == '__main__':
for i in range(5):
buy_food(i)
注意:
并发:指的是任务数多余cpu核数,通过操作系统的各种任务调度算法,实现用多个任务“一起”执行(实际上总有一些任务不在执行,因为切换任务的速度相当快,看上去一起执行而已)
并行:指的是任务数小于等于cpu核数,即任务真的是一起执行的
线程
python的thread模块是比较底层的模块,python的threading模块是对thread做了一些包装的,可以更加方便的被使用
多线程执行:
import threading
import time
def buy_food(num):
print('学生%s买饭' % num)
time.sleep(2)
if __name__ == '__main__':
for i in range(5):
# 创建Thread对象 把任务添加进去 target是要执行的方法 args是传入到方法里的参数
t = threading.Thread(target=buy_food, args=(i,))
# 开启线程执行任务
t.start()
说明:
- 可以明显看出使用了多线程并发的操作,花费时间要短很多
- 当调用start()时,才会真正的创建线程,并且开始执行
查看线程数量
import threading
import time
def sing():
for i in range(3):
print('正在唱歌...%d' % i)
time.sleep(1)
def dance():
for i in range(3):
time.sleep(1)
if __name__ == '__main__':
# 创建线程对象
t1 = threading.Thread(target=sing)
t2 = threading.Thread(target=dance)
t1.start()
t2.start()
while True:
length = len(threading.enumerate())
print('当前运行的线程数为:%d' % length)
if length <= 1:
break
time.sleep(0.5)
线程—注意点
- 每个线程默认有一个名字,尽管上面的例子中没有指定线程对象的name,但是python会自动为线程指定一个名字。
- 当线程的run()方法结束时该线程完成。
- 无法控制线程调度程序,但可以通过别的方式来影响线程调度的方式