import threading
from time import ctime,sleep
import datetime,time
def music(func):
for i in range(2):
print ("I was listening to %s. %s" %(func,ctime()))
sleep(4)
def move(func):
for i in range(3):
print ("I was at the %s! %s" %(func,ctime()))
sleep(3)
#创建了threads数组,创建线程t1,使用threading.Thread()方法
threads = []
t1 = threading.Thread(target=music,args=(u'爱情买卖',)) #target函数名 ,args参数
threads.append(t1)
t2 = threading.Thread(target=move,args=(u'阿凡达',))
threads.append(t2)
if __name__ == '__main__':
t1=datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
#通过for循环遍历数组。(数组被装载了t1和t2两个线程)
for t in threads:
"""将线程声明为守护线程,必须在start() 方法调用之前设置,如果不设置为守护线程程序会被无限挂起。子线程启动后,父线程也继续执行下去,当父线程执行完最后一条语句后,没有等待子线程,直接就退出了,同时子线程也一同结束
"""
t.setDaemon(True)
#开始线程活动。
t.start()
#确保多线程都能执行完毕
"""在子线程完成运行之前,这个子线程的父线程将一直被阻塞。注意: join()方法的位置是在for循环外的,也就是说必须等待for循环里的两个进程都结束后,才去执行主进程。
"""
for t in threads:
t.join()
#线程2结束,程序结束;可能线程1还没执行完毕
# t.join()
print ("all over %s" %ctime())
t2=datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
print('耗时:%ss'%(int(time.mktime(time.strptime(t2, "%Y-%m-%d %H:%M:%S")))-int(time.mktime(time.strptime(t1, "%Y-%m-%d %H:%M:%S")))))