Python threading

2020-01-06 15:35:12 浏览数 (1)

 1.  第一种方式: 创建一个threading.Thread()的实例,给它一个函数。

import threading

代码语言:javascript复制
from time import sleep, ctime

loops = [4, 2]

def loop(nloop, nsec):
    print 'nstart loop:', nloop, 'at:', ctime()
    sleep(nsec)
    print 'nloop', nloop, 'done at:', ctime()

def main():
    print 'nstarting at:n', ctime()
    threads = []
    nloops = range(len(loops))

    #create the threads using threading
    for i in nloops:
         t = threading.Thread(target=loop, args=(i,loops[i]))
         threads.append(t)

    #start threads
    for i in nloops:
        threads[i].start()

    #wait for all
    for i in nloops:
        threads[i].join() #block
        
    print 'nall Done at:', ctime()

if __name__ == '__main__':
    main()

/-----------------------------------------------------------------------------------------------------------------------------------------------------

2. 第二种方式: 创建一个threading.Thread的实例,传给它一个可调用类对象,类中使用__call__()函数调用函数

代码语言:javascript复制
import threading
from time import sleep, ctime

loops = [4,2]

class ThreadFunc(object):
    def __init__(self, func, args, name=''):
        self.name = name
        self.func = func
        self.args = args
    #when you create a new thread, Thread instance will invoke our ThreadFunc
    # instance, and at that time, it will call the function __call__()
    # Hence, we have a tuple arguments , so we use the self.res
    def __call__(self):
        self.res = self.func(*self.args) #invoke the func

def loop(nloop, nsec):
    print 'nstart loop:', nloop, 'at:', ctime()
    sleep(nsec)
    print 'nloop', nloop, 'done at:', ctime()

def main():
    print 'start at:', ctime()
    threads = [] #list
    nloops = range(len(loops))

    #crate all threads
    for i in nloops:
        t = threading.Thread(target=ThreadFunc(loop, (i, loops[i]),loop.__name__))
        threads.append(t)

    #start all threads
    for i in nloops:
        threads[i].start()

    for i in nloops:
        threads[i].join()

    print 'all Done at:', ctime()

if __name__ == '__main__':
    main()
代码语言:javascript复制
/-----------------------------------------------------------------------------------
代码语言:javascript复制
3. 第三种方式: 派生一个threading.Thread出一个子类,创建这个子类的实例,使用run调用函数

import threading 
from time import sleep, ctime

loops = (4,2)

class MyThread(threading.Thread):
    def __init__(self, func, args, name=''):
        threading.Thread.__init__(self) #base class func
        self.name = name
        self.func = func
        self.args = args

    # in the other way, use __call__()
    def run(self):
        apply(self.func,self.args)

def loop(nloop, nsec):
    print 'start loop', nloop, 'at:', ctime()
    sleep(nsec)
    print 'loop', nloop, 'done at:', ctime()

def main():
    print 'starting at:',ctime()
    threads = []
    nloops = range(len(loops))

    for i in nloops:
        t = MyThread(loop, (i,loops[i]), loop.__name__)
        threads.append(t)

    for i in nloops:
        threads[i].start()

    for i in nloops:
        threads[i].join()

    print 'all Done at:', ctime()

if __name__ == '__main__':
    main()

0 人点赞