这周两个晚上在外面吃饭,每次都喝了至少二两。19号又出差去北京,今天才回来,学习有点懈怠。
进程:每一个任务都是一个进程,如打开一个程序(网页,播放器)。进程内的子任务称为线程。
通过multiprocess可以创建一个跨平台的多进程模块。代码来自廖老师教程
from multiprocessing import Process
import os
# 子进程要执行的代码
def run_proc(name):
print('Run child process %s (%s)...' % (name, os.getpid()))
if __name__=='__main__':
print('Parent process %s.' % os.getpid())
p = Process(target=run_proc, args=('test',)) #这是在创建一个子进程
print('Child process will start.')
p.start()
p.join() #join是等待子进程结束后再往下进行
print('Child process end.')
要启动大量子进程时可以用Pool
from multiprocessing import Pool
import os, time, random
def long_time_task(name):
print('Run task %s (%s)...' % (name, os.getpid()))
start = time.time()
time.sleep(random.random() * 3)
end = time.time()
print('Task %s runs %0.2f seconds.' % (name, (end - start)))
if __name__=='__main__':
print('Parent process %s.' % os.getpid())
p = Pool(4)
for i in range(5):
p.apply_async(long_time_task, args=(i,)) #这里创建子进程,并等待操作系统调度运行
print('Waiting for all subprocesses done...') #这一句会打印在第二行,然后才打印long_time_task()的内容,原因在于long_time_task()需要等待时间,而print的时间少于这个等待时间,所以先执行
p.close() #没有p.start(),在于等待操作系统调度运行,禁止新的进程加入
p.join()
print('All done')
创建子进程,运用subprocess模块,可以控制输入、输出
进程间通讯。有Queue,Pipes等方法
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()
点击打开链接 这也有一些讲解