码迷,mamicode.com
首页 > 编程语言 > 详细

指定Python线程数目

时间:2014-09-07 17:09:25      阅读:219      评论:0      收藏:0      [点我收藏+]

标签:des   style   blog   http   color   os   io   ar   strong   

  可以通过threading.semaphore()来指定并行运行的Python线程的数目。

#!/usr/bin/python2.7
#File: threadsNum.py
#Author: lxw
#Time: 2014-09-07
#Usage: Demonstration for control the number of threads.

import threading
from myThread import MyThread
from time import sleep

def fib(x):
    sleep(0.005)
    if x < 2:
        return 1
    return fib(x-2) + fib(x-1)

argList = [13, 11, 15, 12, 14]

def main():
    #Limit the number of threads to 3.
    threadingNum = threading.Semaphore(3)
    threads = []
    for arg in argList:
        t = MyThread(fib, (arg,), threadingNum, fib.__name__+str(arg))
        threads.append(t)

    #There are 5 threads in all, but at most 3 of them run at the same time.
    for thread in threads:
        thread.start()

    for thread in threads:
        #if t is threading.currentThread():
        #    continue
        thread.join()
        print(thread.getResult())

if __name__ == __main__:
    main()
else:
    print(Being imported as a module.)

其中用到的myThread.py如下:

#!/usr/bin/python2.7
#File: myThread.py
#Author: lxw
#Time: 2014-09-06

import threading
from time import ctime

class MyThread(threading.Thread):
    def __init__(self, func, args, num, name=""):
        #if the subclass overrides the constructor, it must make sure to invoke the base class constructor (Thread.__init__()) before doing anything else to the thread.
        threading.Thread.__init__(self)
        self.func = func
        self.args = args
        self.threadingNum = num
        self.name = name

    def getResult(self):
        return self.res

    def run(self):
        #NOTE: "with".
        with self.threadingNum:
            print("start {0} at: {1}".format(self.name, ctime()))
            self.res = apply(self.func, self.args)
            print("end {0} at: {1}".format(self.name, ctime()))

Output:

lxw@lxw-PC:TASK2$ python threadsNum.py 
start fib13 at: Sun Sep  7 16:11:23 2014
start fib11 at: Sun Sep  7 16:11:23 2014
start fib15 at: Sun Sep  7 16:11:23 2014
end fib11 at: Sun Sep  7 16:11:24 2014
start fib12 at: Sun Sep  7 16:11:24 2014
end fib12 at: Sun Sep  7 16:11:26 2014
start fib14 at: Sun Sep  7 16:11:26 2014
end fib13 at: Sun Sep  7 16:11:26 2014
377
144
end fib14 at: Sun Sep  7 16:11:33 2014
end fib15 at: Sun Sep  7 16:11:33 2014
987
233
610

 

Reference:

Python继承类的方式实现多线程及控制线程数: http://lihuipeng.blog.51cto.com/3064864/1322247

指定Python线程数目

标签:des   style   blog   http   color   os   io   ar   strong   

原文地址:http://www.cnblogs.com/lxw0109/p/Control-the-number-of-threads-in-Python.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!