Python Thread和Process对比

原因:进程和线程的差距(方向不同,之针对这个实例)

# coding=utf-8
import logging
import multiprocessing
import os
import time
from threading import Thread

logging.basicConfig(
    level=logging.INFO,
    format="%(asctime)s 【 %(process)d 】 %(processName)s %(message)s"
)


def func (i):
    # logging.info(f'子:{os.getpid()},\t{i}')
    return f'子:{os.getpid()},\t{i}'


def main (ctx):
    start01 = time.time()
    ts = [Thread(target=func, args=(i,)) for i in range(100)]
    [t.start() for t in ts]
    [t.join() for t in ts]
    end01 = time.time() - start01
    logging.info(f"线程花费的时间:{end01}秒")
    
    start02 = time.time()
    ps = [ctx.Process(target=func, args=(i,)) for i in range(100)]
    [p.start() for p in ps]
    [p.join() for p in ps]
    end02 = time.time() - start02
    logging.info(f"进程花费的时间:{end02}秒")


if __name__ == '__main__':
    # windows 启动方式
    multiprocessing.set_start_method('spawn')
    # 获取上下文
    ctx = multiprocessing.get_context('spawn')
    # 检查这是否是冻结的可执行文件中的伪分支进程。
    ctx.freeze_support()
    main(ctx)

输出:

2019-10-06 14:17:22,7297412 】 MainProcess 线程花费的时间:0.0129675865173339842019-10-06 14:17:25,6717412 】 MainProcess 进程花费的时间:2.9418249130249023
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值