import threading
from time import ctime,sleep

class MyThread(threading.Thread):
    """自定义多线程类"""
    def __init__(self,func,args,name=''):
        threading.Thread.__init__(self)
        self.name=name
        self.func=func
        self.args=args
    def run(self):
        """自定义线程执行计时功能"""
        print("线程",self.name,"开始于:",ctime())
        self.res=self.func(*self.args) #执行传入的函数
        print("线程",self.name,"结束于:",ctime())
    def getResult(self):
        """获取线程结果"""
        return self.res

#定义三个测试函数
def fib(x):
    """斐波那契"""
    sleep(0.005)
    if x<2:return 1
    return fib(x-2)+fib(x-1)
def fac(x):
    """阶乘"""
    sleep(0.1)
    if x<2:return 1
    return x*fac(x-1)
def sumsum(x):
    """累加"""
    sleep(0.1)
    if x<2:return 1
    return x+sumsum(x-1)

n=12 #用n求函数结果
funclist=[fib,fac,sumsum] #函数名加入列表

def main():
    nfuncs=range(len(funclist)) #待执行函数数量范围列表
    
    print('单线程执行:')
    print('-'*20)
    for i in nfuncs:
        print('开始执行函数',funclist[i].__name__,"",ctime())
        print('函数',funclist[i].__name__,'的执行结果是:',funclist[i](n))
        print('结束函数',funclist[i].__name__,"",ctime())
        print('*'*20)
    print('-'*20)
    print('多线程执行:')
    threads=[] #线程对象列表
    for i in nfuncs: #将线程对象全部加入列表
        t=MyThread(funclist[i],(n,),funclist[i].__name__) #参数第二个必须是元组
        threads.append(t)
    for i in nfuncs: #开始全部线程
        threads[i].start()
    for i in nfuncs:
        threads[i].join() #等待线程结束
        print(threads[i].getResult()) #打印结果
        #print('函数',threads[i].name,'的执行结果是:',threads[i].getResult()) #打印结果
    print('所有任务完成')

if __name__=='__main__':
    main()