亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 4363 | 回復: 6
打印 上一主題 下一主題

Python多線程問題 [復制鏈接]

論壇徽章:
0
跳轉到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2016-05-20 09:30 |只看該作者 |倒序瀏覽
本帖最后由 z0415010 于 2016-05-20 09:31 編輯

各位好:

遇到一個問題,用戶指定線程數量,來并行執(zhí)行N條命令,請問用多線程怎么實現呢?

我能想到的方法是,先創(chuàng)建用戶指定的線程數量,比如5個,然后先執(zhí)行前5條命令,如果某一個線程結束了,直接從剩余的命令中拿一條繼續(xù)執(zhí)行,直到所有的命令執(zhí)行完。

可是好像不容易實現。

哪位能幫忙實現嗎?謝謝了。

論壇徽章:
5
巨蟹座
日期:2014-08-28 18:12:342015年迎新春徽章
日期:2015-03-04 10:01:4415-16賽季CBA聯賽之江蘇
日期:2016-04-28 09:43:3115-16賽季CBA聯賽之吉林
日期:2016-06-22 10:34:4315-16賽季CBA聯賽之山西
日期:2016-08-16 16:29:55
2 [報告]
發(fā)表于 2016-05-20 11:56 |只看該作者
若干個 線程... lock 方式讀取queue 中的command,取到后釋放...直到queue 為空即可...

論壇徽章:
0
3 [報告]
發(fā)表于 2016-05-20 22:19 |只看該作者
本帖最后由 Hadron74 于 2016-05-20 22:21 編輯

回復 1# z0415010
試著寫了一個,應該滿足你的要求。拋磚引玉:

  1. import threading
  2. import time
  3. from collections import deque

  4. command_list = deque([ "sleep {} ".format(i) for i in range(1,10,1)])

  5. def worker(command):
  6.     from subprocess import call
  7.     call(command,shell=True)
  8.     print "Finished {}".format(command)
  9.     return

  10. NUMBER_THREADS = 5
  11. TIME_INTERVAL = 0.5

  12. def run():
  13.     command = command_list.pop()
  14.     t = threading.Thread(target=worker, args=(command,))
  15.     t.start()

  16. for i in range(NUMBER_THREADS):
  17.     run()

  18. while command_list:
  19.     time.sleep(TIME_INTERVAL)
  20.     alive_threads = threading.enumerate()
  21.     lat = len(alive_threads)
  22.     if lat == 1 : break
  23.     if lat <= NUMBER_THREADS : run()
復制代碼
  1. Finished sleep 5
  2. Finished sleep 6
  3. Finished sleep 7
  4. Finished sleep 8
  5. Finished sleep 9
  6. Finished sleep 4
  7. Finished sleep 1
  8. Finished sleep 2
  9. Finished sleep 3
復制代碼

論壇徽章:
33
榮譽會員
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT運維版塊每日發(fā)帖之星
日期:2016-04-17 06:23:27操作系統(tǒng)版塊每日發(fā)帖之星
日期:2016-04-18 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-04-24 06:20:0015-16賽季CBA聯賽之天津
日期:2016-05-06 12:46:59
4 [報告]
發(fā)表于 2016-05-20 22:42 |只看該作者
回復 1# z0415010

multithreading 中有現成的實現, 還有現成的例子。


   

論壇徽章:
0
5 [報告]
發(fā)表于 2016-05-20 22:48 |只看該作者
回復 4# q1208c

能貼出來嗎?多線程不熟,正好學學。謝謝!
   

論壇徽章:
4
程序設計版塊每日發(fā)帖之星
日期:2015-10-14 06:20:00每日論壇發(fā)貼之星
日期:2015-10-14 06:20:00程序設計版塊每日發(fā)帖之星
日期:2016-05-02 06:20:00程序設計版塊每日發(fā)帖之星
日期:2016-05-08 06:20:00
6 [報告]
發(fā)表于 2016-05-21 11:03 |只看該作者
假設你使用的是multiprocessing的Pool,是使用多進程實現了concurrency
from multiprocessing import Pool
如果把這個代碼改成下面這樣,就變成多線程實現concurrency
from multiprocessing.dummy import Pool
兩種方式都跑一下,哪個速度快用哪個就行了。

這個參考不錯
h ttps://segmentfault.com/a/1190000000414339

論壇徽章:
0
7 [報告]
發(fā)表于 2016-05-21 15:07 |只看該作者
回復 6# mswsg

這個好!
   
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術有限公司. 版權所有 京ICP備16024965號-6 北京市公安局海淀分局網監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯網協(xié)會會員  聯系我們:huangweiwei@itpub.net
感謝所有關心和支持過ChinaUnix的朋友們 轉載本站內容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP