在Python中我们主要是通过thread和threading这两个模块来实现的,其中Python的threading模块是对thread做了一些包装的,可以更加方便的被使用,所以我们使用threading模块实现多线程编程。一般来说,使用线程有两种模式,一种是创建线程要执行的函数,把这个函数传递进Thread对象里,让它来执行;另一种是直接从Thread继承,创建一个新的class,把线程执行的代码放到这个新的 class里。

将函数传递进Thread对象

Python代码

  1. '''''
  2. Created on 2012-9-5
  3. @author:  walfred
  4. @module: thread.ThreadTest1
  5. @description:
  6. '''
  7. import threading 
  8. def thread_fun(num): 
  9. for n in range(0, int(num)): 
  10. print " I come from %s, num: %s" %( threading.currentThread().getName(), n) 
  11. def main(thread_num): 
  12.     thread_list = list(); 
  13. # 先创建线程对象
  14. for i in range(0, thread_num): 
  15.         thread_name = "thread_%s" %i 
  16.         thread_list.append(threading.Thread(target = thread_fun, name = thread_name, args = (20,))) 
  17. # 启动所有线程  
  18. for thread in thread_list: 
  19.         thread.start() 
  20. # 主线程中等待所有子线程退出
  21. for thread in thread_list: 
  22.         thread.join() 
  23. if __name__ == "__main__": 
  24.     main(3) 

        程序启动了3个线程,并且打印了每一个线程的线程名字,这个比较简单吧,处理重复任务就派出用场了,下面介绍使用继承threading的方式;

继承自threading.Thread类

Python代码

  1. '''''
  2. Created on 2012-9-6
  3. @author: walfred
  4. @module: thread.ThreadTest2
  5. '''
  6. import threading 
  7. class MyThread(threading.Thread): 
  8. def __init__(self): 
  9.         threading.Thread.__init__(self); 
  10. def run(self): 
  11. print "I am %s" %self.name 
  12. if __name__ == "__main__": 
  13. for thread in range(0, 5): 
  14.         t = MyThread() 
  15.         t.start() 

        接下来的文章,将会介绍如何控制这些线程,包括子线程的退出,子线程是否存活及将子线程设置为守护线程(Daemon)。