python——多任务

linux才是真正的多用户多任务
多任务,一般是通过时间片轮转和优先级调度等实现并发

进程

正在运行着的代码

线程
fork
import  os
import time
ret = os.fork()
if ret == 0:
    while True:
        print("xjxjxjxjjx")
        time.sleep(1)
else:
    while True:
        print("22222222")
        time.sleep(1)
xjxjxjxjjx
xjxjxjxjjx
22222222
xjxjxjxjjx
22222222
xjxjxjxjjx
22222222
xjxjxjxjjx
22222222

getpid返回当前进程标识,getppid返回父进程标识。父进程中fork的返回值就是刚刚创建的子进程的id

import  os
ret = os.fork()
print(ret)
if ret > 0:
    print("父进程---%d"%os.getpid())       
else:
    print("子进程---%d %d"%(os.getpid(),os.getppid()))
-----------------------------------------------------------------------
23644
父进程---23643
0
子进程---23644 23643

父进程和子进程的执行顺序

import  os
import time
ret = os.fork()
if ret == 0:
    print("子进程1111")
    time.sleep(5)
    print("子进程2---")        
else:
    print("父进程---")
    time.sleep(3)

print("------over------")
-------------------------------------------------
父进程---
子进程1111
------over------
EPOQUEs-MacBook-Pro:plane epoque$ 子进程2---
------over------
多进程修改全局变量

进程之间不会共享数据

import  os
import time
num = 100
ret = os.fork()
if ret == 0:
    print("111111111")
    num += 1    
    print("子进程%d"%num)  
else:
    time.sleep(3)
    print("22222222")
    print("父进程%d"%num)
——————————————————————————
111111111
子进程101
22222222
父进程100  

多个进程的运行顺序

import  os
import time
ret = os.fork()
if ret == 0:
    print("111111111")      
else:
    print("22222222")
    
ret = os.fork()
if ret == 0:
    print("333333333333")       
else:
    print("44444444444")
______________________________
22222222
44444444444
111111111
333333333333
44444444444
333333333333

fork不夸平台,只能在linux上使用,所以一般用Process,这个主进程会等所有子进程运行完主进程才能结束,此处和fork不一样。所以,一般不用fork

from multiprocessing import Process
import time

def test():
    while True:
        print("-----test-----")
        time.sleep(1)
p = Process(target=test)
p.start()
while True:
    print("main")
    time.sleep(1)           
————————————————————————————
main
-----test-----
-----test-----
main
-----test-----
main
-----test-----
main
-----test-----
main
-----test-----
……
jion(timeout)子进程

等到标记的进程结束之后,才会往下走(等待时间)。

from multiprocessing import Process
import time
import random


def test():
   for i in range(random.randint(1,5)):
       print("-----test-----%d"%i)
       time.sleep(1)
p = Process(target=test)
p.start()
p.join() #堵塞 
print("main")
 ————————————————————————————————          
-----test-----0
-----test-----1
-----test-----2
-----test-----3
main
进程的创建——Process子类
from multiprocessing import Process
import time


class MyNewProcess(Process):
  def run(self):
      while True:
          print("----1-----")
          time.sleep(1)
      
p = MyNewProcess()
p.start()

while True:
  print("-----main_--___")
  time.sleep(1)
——————————————————————————————————
-----main_--___
----1-----
----1-----
-----main_--___
----1-----
-----main_--___
----1-----
-----main_--___
----1-----
……
进程池
image.png

如果添加的任务数量超过了进程池的进程个数的话,那么不会导致添加不进入添加到进程中的任务,如果还没有被执行的话,那么此时,他们会等待进程池中的进程完成一个任务后,会自动去用刚刚那个进程,完成新的任务

from multiprocessing import Pool
import time
import random
import os

def worker():
    for i in range(5):
        print("_______pid=%d  i=%d"%(os.getpid(),i))
        time.sleep(1)
#表示进程池中最多有三个进程      
pool = Pool(3)
for i in range(10):
    print("%d"%i)
    pool.apply_async(worker)
#关闭进程池,就不能再添加新的任务           
pool.close()
#如果没有join,会导致进程池中的任务不会执行
pool.join()

堵塞就相当于是单线程了

pool.apply(woker,(i,))
进程间通信-Queue
from multiprocessing import Queue
 q = Queue()
 q.empty()
 q.full()
 q.get()

多进程copy文件

from multiprocessing import Pool,Manager
import os

def copyFileTask(name, oldFolderName, newFolderName,queue):
    #文件的copy功能
    fr = open(oldFolderName +"/"+name)
    fw = open(newFolderName+"/"+name,"w")
    content = fr.read()
    fw.write(content)
    fr.close()
    fw.close()
    queue.put(name)

def main():
    #1、创建一个文件夹
    oldFolderName = input("输入文件夹的名字:")
    newFolderName = oldFolderName + "_复件"
    os.mkdir(newFolderName)
    #2、获取old文件夹中的所有文件名
    fileNames = os.listdir(oldFolderName)
    print(fileNames)
    #3、使用多进程copy,源文件夹中的所有文件到新文件夹中
    pool = Pool(5)
    queue = Manager().Queue()
    for name in fileNames:
        pool.apply_async(copyFileTask,args=(name, oldFolderName, newFolderName,queue))
    num = 0
    allNum = len(fileNames)
    while num<allNum:
        queue.get()
        num+=1
        copyrate = (num/allNum)*100
        print("进度%.2f%%"%copyrate)

if __name__ == "__main__":
    main()
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,843评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,538评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,187评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,264评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,289评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,231评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,116评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,945评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,367评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,581评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,754评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,458评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,068评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,692评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,842评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,797评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,654评论 2 354

推荐阅读更多精彩内容

  • 一个任务是一个进程,进程内的子任务称为线程。多任务的实现有3种方式: 多进程模式; 多线程模式; 多进程+多线程模...
    JEZAU阅读 4,961评论 0 2
  • 对多进程的补充 对比下面两段代码 if name=='main':... print('Parent pr...
    JEZAU阅读 503评论 0 0
  • 又来到了一个老生常谈的问题,应用层软件开发的程序员要不要了解和深入学习操作系统呢? 今天就这个问题开始,来谈谈操...
    tangsl阅读 4,124评论 0 23
  • Linux 进程管理与程序开发 进程是Linux事务管理的基本单元,所有的进程均拥有自己独立的处理环境和系统资源,...
    JamesPeng阅读 2,467评论 1 14
  • 感赏儿子今天按时上学不迟到。 感赏儿子中午吃午饭吃了很多,按时睡午觉。中午我送他到学校门口和我说回去吧,以前不说的...
    宁静致远自由飞翔阅读 189评论 1 2