进程 线程

这周两个晚上在外面吃饭,每次都喝了至少二两。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()
点击打开链接   这也有一些讲解
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值