Python简单多进程demo

 

'''
多线程使用场景:
怎样用Python的多线程提高效率?
io操作不占用CPU
计算操作占用CPU
Python多线程不适合CPU操作密集型的任务,适合io操作密集型的任务
如果有CPU操作密集型的任务需要用多进程,启动八个进程每个进程里一个线程,一共八个线程
在八核上运行,可以利用八核了,唯一的坏处是数据不能共享
怎样启动多进程呢?
'''
import multiprocessing
import time
import threading

# 功能:启动10个进程,每个进程里启动一个线程
def thread_run():
    print(threading.get_ident())
def run(name):
    time.sleep(2)
    print("hello",name)
    t = threading.Thread(target=thread_run,)
    t.start()
if __name__ == '__main__':
    for i in range(10):
        p = multiprocessing.Process(target=run, args=('bob{0}'.format(i),))
        p.start()

 打印子进程和父进程信息:

'''
每个进程都是由他的父进程启动的,每个进程都有一个父进程
'''
import os
from multiprocessing import Process

def info(title):
    print(title)
    print('module name:',__name__)  # 模块名
    print('parent process:',os.getppid())  # 父进程ID
    print('process id:', os.getpid())      # 本进程ID
    print('\n\n')

def f(name):
    info('\033[31;1mfunction f\033[0m')
    print('hello',name)

if __name__ == '__main__':
    info('\033[32;1m main process line\033[0m')
    p = Process(target=f, args=('bob',))
    p.start()
    p.join()

'''
 main process line
module name: __main__
parent process: 4436
process id: 6032



function f
module name: __mp_main__
parent process: 6032
process id: 5800



hello bob
'''

 

posted on 2018-09-23 11:07 要一直走下去 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/staff/p/9692213.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值