Python-多线程和多进程
2018-11-12
本博客所有文章采用的授权方式为 自由转载-非商用-非衍生-保持署名 ,转载请务必注明出处,谢谢。
声明: 本博客欢迎转发,但请保留原作者信息!
github地址:atanx
新浪微博:@蜀山掌门V
QQ:365039667
博客地址:江斌的博客
内容仅供学习参考,如有不当引用,请告知博主。
多线程
- setDameon(True) 设置守护进程,守护进程最后退出
- join() 阻塞主线程
- join(3) 阻塞主线程3s,主线程结束,子线程仍会继续执行至完成
- setDameon(True) join()同时使用时,主线程结束,子线程也结束。
多进程
## 示例1
```python
#!/usr/bin/env python
#coding=utf-8
from multiprocessing import Pool, Queue
import os, time,random
def do_task(name):
print "Run task {name}".format(name=name)
st = time.time()
time.sleep(3)
et = time.time()
print "Task {name} runs {dur} seconds".format(name=name, dur=et-st)
if __name__ == '__main__':
print "Parent process {pid}".format(pid=os.getpid())
p=Pool(4)
for i in range(5):
p.apply_async(do_task, args=(i,))
p.close()
p.join()
print('All subprocesses donw')
示例2
from multiprocessing import Process, Queue
import os, time, random
# 写数据进程执行的代码:
def write(q):
print('Process to write: %s' % os.getpid())
for value in ['A', 'B', 'C']:
print('Put %s to queue...' % value)
q.put(value)
time.sleep(random.random())
# 读数据进程执行的代码:
def read(q):
print('Process to read: %s' % os.getpid())
while True:
value = q.get(True)
print('Get %s from queue.' % value)
if __name__=='__main__':
# 父进程创建Queue,并传给各个子进程:
q = Queue()
pw = Process(target=write, args=(q,))
pr = Process(target=read, args=(q,))
# 启动子进程pw,写入:
pw.start()
# 启动子进程pr,读取:
pr.start()
# 等待pw结束:
pw.join()
# pr进程里是死循环,无法等待其结束,只能强行终止:
pr.terminate()
```