关于Threading多线程的一些解析
先来一个正常的for循环:遍历0-9
#@Time : 2020-12-07
#@Author : LBOcean
"""
进程:正在运行的程序
线程:cpu调度的单位,一个进程可以包含多个线程
多线程: 合适IO密集型
多进程: cpu密集型任务
"""
import threading
import time
def my_print(name):
for i in range(10):
time.sleep(1)#休息一秒在进行下一个循环
print(name,i)
start = time.time()#返回当前的时间戳
my_print('threading1')
my_print('threading2')
end = time.time()
print(end-start)
print("结束")
上面我们可以看到,运行了用了20秒多一点点点点
若我们用多线程的话,就相当于两个for循环切换着运行,threading2就不会等threading1运行完了,再运行了.
#@Time : 2020-12-07
#@Author : LBOcean
#name : Mashine_S
"""
进程:正在运行的程序
线程:cpu调度的单位,一个进程可以包含多个线程
多线程: 合适IO密集型
多进程: cpu密集型任务
"""
import threading
import time
def my_print(name):
for i in range(10):
time.sleep(1)休息一秒在进行下一个循环
print(name,i)
start = time.time()#返回当前的时间戳
t1 = threading.Thread(target = my_print,args = ["threading1:"]) #传个任务,和参数进来
t2 = threading.Thread(target = my_print,args = ['threading2:'])
t1.start()#线程开始
t2.start()
t1.join()
t2.join()
end = time.time()
print(end-start)
print("结束")
上面我们可以看到,只花了十秒多一点点点点,就运行完了。
两条线程并发,来完成这个程序。
至于为什么会出现这种情况,这里解释一下:
因为线程在切换!也就是说当运行threading1的时候刚输出完name,没有来的及i,线程就切换到threading2了.
那么如何解决这种问题呢?
就需要用到线程锁了,线程锁我们下一章再讲!