zoukankan      html  css  js  c++  java
  • 【Python高级编程004 ● 多任务编程 ● 进程之间不共享全局变量】


    ---------Python基础编程---------

    Author : AI菌


    【内容讲解】

    进程之间不共享全局变量:
        创建子进程会对主进程资源进行拷贝,也就是说子进程是主进程的一个副本,好比是一对双胞胎。
        之所以进程之间不共享全局变量,是因为操作的不是同一个进程里面的全局变量,
        只不过不同进程里面的全局变量名字相同而已。

    【代码演示】

    """
    进程之间不共享全局变量:
        创建子进程会对主进程资源进行拷贝,也就是说子进程是主进程的一个副本,好比是一对双胞胎。
        之所以进程之间不共享全局变量,是因为操作的不是同一个进程里面的全局变量,
        只不过不同进程里面的全局变量名字相同而已。
    """
    
    import multiprocessing
    
    # 测试代码
    # result = type([])
    # print(result)
    
    # 定义全局变量
    g_list = list()
    
    
    # 向全局变量添加数据
    def add_data():
        for i in range(3):
            g_list.append(i)
            print("add_data:", i)
        print("添加数据完毕后,add_data_process子进程中全局变量g_list:", g_list)
    
    
    # 读取全局变量的数据
    def read_data():
        print("read_data:", g_list)
    
    
    if __name__ == '__main__':
        # 添加数据进程
        add_data_process = multiprocessing.Process(target=add_data)
        # 读取数据进程
        read_data_process = multiprocessing.Process(target=read_data)
    
        # 启动进程执行对应的任务
        add_data_process.start()
        # 进程等待join, 主进程会等待子进程(add_data_process)执行完成以后,再继续执行下面的代码
        add_data_process.join()
        # 启动进程执行对应的任务
        read_data_process.start()
    
        print("主进程中全局变量g_list:", g_list)

    【运行结果】

    add_data: 0
    add_data: 1
    add_data: 2
    添加数据完毕后,add_data_process子进程中全局变量g_list: [0, 1, 2]
    主进程中全局变量g_list: []
    read_data: []

    【结果说明】

    1、add_data_process子进程中对全局变量g_list添加数据,添加完毕后,
    主进程和read_data_process中的全局变量g_list并没有添加数据,
    说明进程之间不共享全局变量。
    2、主进程、读数据进程和修数据进程, 三个进程分别操作的都是自己进程里面的全局变量my list, 不会对其它进程里面的全局变量产生影响, 所以进程之间不共享全局变量,只不过进程之间的全局变量名字相同而已, 但是操作的不是同一个进程里面的全局变量。

    【往期精彩】

    ▷【Python基础编程196 ● 读取文件的4种方式】
    ▷【Python基础编程197 ● 读取文件的4种方式】
    ▷【Python基础编程198 ● 读取文件的4种方式】
    ▷【Python基础编程199 ● Python怎么读/写很大的文件】
    ▷【Python基础编程200 ● 读取文件的4种方式】
    ▷【Python基础编程201 ● 读取文件的4种方式】
    ▷【Python基础编程202 ● 读取文件的4种方式】
    ▷【Python基础编程203 ● 读取文件的4种方式】

    【加群交流】



  • 相关阅读:
    EF6 在原有数据库中使用 CodeFirst 总复习(三、重建迁移)
    EF6 在原有数据库中使用 CodeFirst 总复习(四、新建实体对象)
    EF6 在原有数据库中使用 CodeFirst 总复习(五、生成发帖页面)
    实体框架 (EF) 入门 => 一、我该用哪个工作流?
    实体框架 (EF) 入门 => 二、在全新的数据库中使用 Code First
    asp.net core 2.0 webapi集成signalr
    实体框架 (EF) 入门 => 三、CodeFirst 支持的完整特性列表
    ORM框架之------Dapper,Net下无敌的ORM
    Dapper Helper
    .NET平台微服务项目汇集
  • 原文地址:https://www.cnblogs.com/hezhiyao/p/13603355.html
Copyright © 2011-2022 走看看