以阶乘计算为例,例如计算一个30的阶乘,强行把他四等分,从1乘到6,6乘到15,以此类推,最后把四个部分的结果乘起来
# -*- coding: utf-8 -*-
"""
Created on Fri Mar 15 22:58:08 2019
@author: Minghua Chen
"""
import threading
from time import ctime
anser=[]#答案集,四次计算的答案扔到这个集合里面
def fact(a,b): #目标函数,需要计算四次的目标
sumx=1
for i in range(a,b):
sumx=sumx*i
anser.append(sumx)
def main():
print 'starting at: ', ctime()
threads=[]#线程的集合,现在是空的,因为还没做线程
for i in range(len(half)-1):
t=threading.Thread(target=fact,
args=(half[i],half[i+1]))#制造线程,目标函数,并给这个函数导入参数,这个函数(fact)需要两个参数,args括号里就跟两个,如果四个函数要求是不一样的,那我们不要用这个循环,改成四次threading.Thread和append就行
threads.append(t)#把做出来的线程放到刚才那个空的线程包里
for i in range(len(half)-1):#
threads[i].start()#一一启动线程包里的每一个线程,四个线程同时燃烧
for i in range(len(half)-1):
threads[i].join()#每个线程的结束时间可能是不一样的,用join()确认他们都结束了
s=1
for i in anser:#这时候结果包里有刚才四个线程得到的四个结果,至于他们的先后顺序,这取决于他们谁先结束,把四个结果乘在一起
s=s*i
print s
print 'all DONE at: ', ctime()
if __name__ =='__main__':
x=3000
half=[1,x/4,x/2,3*x/4,x]
main()
print 'starting again at: ', ctime()#不用多线程时的结果,验算一下两个是不是一样(当然是一样的)
sumx=1
for i in range(1,3000):
sumx*=i
print sumx
print 'end again at: ', ctime()