python多线程

本文介绍了一个Python多线程的示例程序,演示如何创建并管理多个线程,包括设置守护线程及主线程等待子线程结束的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


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")))))    
结果:

学习:http://www.cnblogs.com/fnng/p/3670789.html



                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值