美文网首页
2018-04-02

2018-04-02

作者: mo_陌上花开 | 来源:发表于2018-04-02 22:03 被阅读0次

python高级

多线程通讯

队列 Queue---来完成多进程间的数据传递

#引进相对应的模块
from multiprocessing import Process,Queue
#引进时间模块
import time

def send(q):
    
    print("发送数据的子进程 " )
    #像对列中添加一条数据
    q.put("我是你爸爸~~~")
    #时间间隔为一秒
    time.sleep(1)
        
def revice(q):
    
    print("接收数据的子进程")
    #从队列中获取数据
    d = q.get()
    print("接收的数据-->%s" % d)
    #时间间隔为一秒
    time.sleep(1)
        
if __name__ == "__main__":
    #定义队列变量
    q = Queue()
    
    t1 = Process(target=send, args = [q,],name = "sendd")
    t1.start()
    
    t2 = Process(target=revice,args = [q,],name = "reviced")
    t2.start()
    

管道 Pipe---方式单一

#引进相对应的方法模块
from multiprocessing import Process,Pipe
#引进时间模块
import time


def send(q):
    print("发送数据的子进程 ")
    # 像对列中添加一条数据
    q.send("我是你爸爸~~~")
    q.close()
    # 时间间隔为一秒
    time.sleep(1)


def revice(q):
    print("接收数据的子进程")
    # 从队列中获取数据
    d = q.recv()
    print("接收的数据-->%s" % d)
    # 时间间隔为一秒
    time.sleep(1)


if __name__ == "__main__":
    #接受返回的元组
    (parent_pipe,son_pipe) = Pipe()
    
    t1 = Process(target=send, args=(son_pipe,), name="sendd")
    t1.start()
    
    t2 = Process(target=revice, args=(parent_pipe,), name="reviced")
    t2.start()

管理器 Manager---数据共享

#应用相对应的模块
from multiprocessing import Process,Manager
#引用时间模块
#import time

def send(list,dict):
    list.append("老刘")
    list.append("老张")
    list.append("老李")
    dict["name"] = "梅前途"
    dict["age"] = "20"
    dict["gender"] = "男"
    
    print(list)
    print(dict)
    
if __name__ == "__main__":

    with Manager() as manager:
        #获取一个列表
        list = manager.list()
        #获取一个字典
        dict = manager.dict()
        
        ls = []
        
        for x in range(10):
            task = Process(target = send, args = (list,dict))
            task.start()
            
            ls.append(task)
        
        for x in ls:
            x.join()

模拟上传下载

#引入分隔模块
from multiprocessing import Process
#引入时间模块
import time
#引入时间模块
import os


def download(path):
    print("开始下载~~~")
    for x in range(5):
        print("正在下载中%s~~~" % path)
        print(os.getpid())
        print(os.getppid())
        time.sleep(1)
    print("下载结束")
    
def printMsg(msg):
    print("开始打印~~~")
    for x in range(5):
        print("正在打印中%s" % msg)
        print(os.getpid())
        print(os.getppid())
        time.sleep(1)
        
    print("打印结束")
    
if __name__ == "__main__":
    #启动的时间
    start_time = time.time()
    
    t1 = Process(target = download, args = ("www.yellow.com",), name = "download")
    #启动下载
    t1.start()
    
    t2 = Process(target= printMsg, args = ("刘国营是个大帅哥",), name = "peintMsg")
    #启动打印
    t2.start()
    
    print("程序结束", time.time() - start_time)
    

相关文章

  • 2018-04-02

    2018-04-02 王晓艳_6d4c 2018-04-02 00:20 · 字数 98 · 阅读 0 · 日记本...

  • knn约会实例2

    2018-04-02 分析数据:使用Matplotib创建散点图 https://www.cnblogs.com/...

  • 2018-04-02

    2018-04-02 180 戴师傅 简书作者 2018.04.02 21:07 打开App 2018-04-02...

  • 2018-04-02

    2018-04-02 180 戴师傅 简书作者 2018.04.02 22:09 打开App 2018-04-03...

  • 2018-04-02

    嘿,穷小子,2018炒股你得...... 2018-04-02 ​​​​ 因为我没有钱了, 所以出来挣钱了。 ...

  • 2018-04-03

    2018-04-02 想念99 2018-04-03 22:42 · 字数 712 · 阅读 0 · 日记本 上周...

  • 不要浪费自己的人生

    你好,四月!时间可以浪费,人生不能! 晓多 关注 2018-04-02 23:03 · 字数 3754 · 阅读 ...

  • 四月,新的国旗班!

    2018-04-02桂林理工大学国旗班 Apr.1 NO.2 Guilin Polytechnic Univers...

  • 2018-04-02

    2018-04-02 180 戴师傅 简书作者 2018.04.02 20:43 打开App (稻盛哲学学习会)打...

  • 傍晚游开封西湖

    艳阳天边挂,微风拂面颊。 俗气水中取,自在走天涯。 写于2018-04-02 10:15:36

网友评论

      本文标题:2018-04-02

      本文链接:https://www.haomeiwen.com/subject/pqkfhftx.html