import threading
import time
from mytimeit import timeit
import multiprocessing
def job(li):
return sum(li)
@timeit
def use_thread():
li = range(1, 100000000)
# create 5 threads
threads = []
for i in range(5):
t = threading.Thread(target=job, args=(li, ))
t.start()
threads.append(t)
[thread.join() for thread in threads]
@timeit
def use_no_thread():
li = range(1, 100000000)
for i in range(5):
job(li)
@timeit
def use_process():
li = range(1, 100000000)
# create 5 threads
processes = []
# 1). 开启的进程书是有瓶颈的, 取决于CPU个数,
# 2). 如果处理的数据比较小, 不建议使用多进程,因为创建进程和销毁进程需要时间;
# 3). 如果处理数据足够大, 0《进程数《cpu个数;
for i in range(5):
p = multiprocessing.Process(target=job, args=(li,))
p.start()
processes.append(p)
[process.join() for process in processes]
if __name__ == "__main__":
use_thread()
use_process()
use_no_thread()
进程与线程的选择取决以下几点:
1、需要频繁创建销毁的优先使用线程;因为对进程来说创建和销毁一个进程代价是很大的。
2、线程的切换速度快,所以在需要大量计算,切换频繁时用线程,还有耗时的操作使用线程可提高应用程序的响应
3、因为对CPU系统的效率使用上线程更占优,所以可能要发展到多机分布的用进程,多核分布用线程;
4、并行操作时使用线程,如C/S架构的服务器端并发线程响应用户的请求;
5、需要更稳定安全时,适合选择进程;需要速度时,选择线程更好。