python thread 并發(fā)且順序運行示例
更新時間:2009年04月09日 12:14:17 作者:
以上源文件是對python中的線程的一個簡單應用,實現了對并發(fā)線程的順序運行,也許對你會有小小幫助
復制代碼 代碼如下:
#-*- coding:utf-8 -*-
import threading
import time
def fun(name, ls_name, front_thread = None):
'''''
線程啟動函數
通過front_thread來使用線程有序的運行
'''
time.clock()
time.sleep(2)
# 如果front_thread存在,則在front_thread運行完成后,才運行當前線程
if front_thread != None:
front_thread.join()
ls_name.append(name)
print "thread %s : %s"% (name, time.clock())
if __name__ == '__main__':
ls_result_name = []
ls_thread = []
time.clock()
# 逐一啟動1000個線程
for i in range(0,10):
if len(ls_thread) == 0:
t = threading.Thread(target=fun, args=(i,ls_result_name,None))
else:
t = threading.Thread(target=fun, args=(i,ls_result_name,ls_thread[-1]))
t.start()
ls_thread.append(t)
# 等待所有線程結束
for t in ls_thread:
t.join()
print 'ls_result_name:', ls_result_name
print "main thread:%s" % time.clock()
運行結果為:
thread 0 : 1.99962006344
thread 1 : 2.00000866032
thread 2 : 2.00059113658
thread 3 : 2.00080345407
thread 4 : 2.00100068584
thread 5 : 2.00119456523
thread 6 : 2.00138593033
thread 7 : 2.00166753037
thread 8 : 2.00211758757
thread 9 : 2.0024776892
ls_result_name: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
main thread:2.003211302
線程更明細的使用可參考:
http://docs.python.org/library/threading.html
time.clock模塊的更詳細介紹可參考:
http://blog.csdn.net/kiki113/archive/2009/03/28/4033017.aspx
相關文章
Python Web框架之Django框架cookie和session用法分析
這篇文章主要介紹了Python Web框架之Django框架cookie和session用法,結合實例形式分析了Django框架cookie和session的常見使用技巧與操作注意事項,需要的朋友可以參考下2019-08-08
一文帶你掌握Python中enumerate函數和for循環(huán)的對比
在Python編程中,循環(huán)是一項常見的任務,而for循環(huán)是最常見的一種,然而,Python提供了enumerate函數,它允許在迭代過程中訪問元素的同時獲得它們的索引,下面我們就來學習一下二者的區(qū)別吧2023-11-11

