python多线程multiprocessing使用

使用python multiprocessing模块多线程创建空文件

 

#!/usr/bin/env python  
#-*- coding: UTF-8 -*-

import os
import multiprocessing
import sys

def run(srcpath):
    if os.path.exists(srcpath):
        for i in xrange(1):  #创建100个一级目录
            firstPath = srcpath + os.sep + "tfs" + str(i)
            if not os.path.exists(firstPath):
                os.mkdir(firstPath)
            index = 0
            for j in xrange(1):  #创建200个二级目录
                secondPath = firstPath + os.sep + "tfs" + str(j)
                if not os.path.exists(secondPath):
                    os.mkdir(secondPath)
                #创建2亿个文件为10000个, 创建1亿个文件为5000个,创建1000万个文件为500,创建100万个文件为50
                while index < 1000:  
                    fileName = secondPath + os.sep + "tfs_file" + str(index)
                    f = open(fileName, "w")
                    f.write("1")
                    f.close()
                    #建立空文件
#                    os.mknod(fileName)
                    index += 1
            index = 0
                
    
if __name__ == "__main__":
    subprocNums = int(sys.argv[1])
    srcpath = sys.argv[2]
    procNum = 0
    while procNum < subprocNums:
        procNum = procNum + 1
        subProc = multiprocessing.Process(target=run,args=(srcpath,))
        subProc.start()
        print 'has start subprocess', procNum

2、使用进程池

是的,你没有看错,不是线程池。它可以让你跑满多核CPU,而且使用方法非常简单。

注意要用apply_async,如果落下async,就变成阻塞版本了。

processes=4是最多并发进程数量。

import multiprocessing

import time

 

def func(msg):

    for i in xrange(3):

        print msg

        time.sleep(1)

 

if __name__ == "__main__":

    pool = multiprocessing.Pool(processes=4)

    for i in xrange(10):

        msg = "hello %d" %(i)

        pool.apply_async(func, (msg, ))

    pool.close()

    pool.join()

    print "Sub-process(es) done."

3、使用Pool,并需要关注结果

更多的时候,我们不仅需要多进程执行,还需要关注每个进程的执行结果,如下:

import multiprocessing

import time

 

def func(msg):

    for i in xrange(3):

        print msg

        time.sleep(1)

    return "done " + msg

 

if __name__ == "__main__":

    pool = multiprocessing.Pool(processes=4)

    result = []

    for i in xrange(10):

        msg = "hello %d" %(i)

        result.append(pool.apply_async(func, (msg, )))

    pool.close()

    pool.join()

    for res in result:

        print res.get()

    print "Sub-process(es) done."


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值