• 【Python高级编程015 ● 多任务编程 ● 线程同步的方式一:线程等待join】



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

    Author : AI菌


    【内容讲解】

    一、线程之间共享全局变量数据出现错误问题的解决办法:线程同步
    二、线程同步的理解:
        线程同步: 就是保证同一时刻只能有一个线程去操作全局变量;
        同步: 就是协同步调,按预定的先后次序进行运行;
        注意:同步不是一起执行的意思,需要与日常生活中的同步区分开。
    二、线程同步的两种方式:
        1、线程等待(join)
        2、互斥锁

    【代码演示】

    """
    一、线程之间共享全局变量数据出现错误问题的解决办法:线程同步
    二、线程同步的理解:
        线程同步: 就是保证同一时刻只能有一个线程去操作全局变量;
        同步: 就是协同步调,按预定的先后次序进行运行;
        注意:同步不是一起执行的意思,需要与日常生活中的同步区分开。
    二、线程同步的两种方式:
        1、线程等待(join)
        2、互斥锁
    """
    
    # 定义两个函数,实现循环100万次,每循环一次给全局变量加1
    # 创建两个子线程执行对应的两个函数,查看计算后的结果
    # 如果计算过程不出错,两个子线程执行完毕,全局变量的值应该是200万
    
    import threading
    
    # 定义全局变量
    g_num = 0
    
    
    # 循环1000000次,每循环一次给全局变量加1
    def calc_num1():
        # 声明此处加上global表示要修改全局变量的内存地址
        global g_num
        for i in range(1000000):
            g_num += 1
    
        print("calc_num1:", g_num)
    
    
    # 循环1000000次,每循环一次给全局变量加1
    def calc_num2():
        # 声明此处加上global表示要修改全局变量的内存地址
        global g_num
        for i in range(1000000):
            g_num += 1
    
        print("calc_num2:", g_num)
    
    
    if __name__ == '__main__':
        # 创建第一个子线程
        first_thread = threading.Thread(target=calc_num1)
        # 创建第二个子线程
        second_thread = threading.Thread(target=calc_num2)
    
        # 启动线程执行任务
        first_thread.start()
    
        # 主线程等待第一个子线程执行完成以后程序再执行(线程同步)
        first_thread.join()
    
        # 启动线程执行任务
        second_thread.start()

    【运行结果】

    calc_num1: 1000000
    calc_num2: 2000000

    【往期精彩】

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

    【加群交流】



  • 相关阅读:
    5.4 类型转换
    IntelliJ IDEA 创建Web项目(全教程)
    Spring IoC 依赖注入的方法大全 XML配置方式
    20秒教你如何写maven2的pom文件的依赖包
    数据库面试题之COUNT(*),COUNT(字段),CONUT(DISTINCT 字段)的区别
    Oracle中的单行函数
    Select 子句后的别名,在where条件中不能使用
    Oracle SQL*Plus命令
    使用js请求Servlet时的路径
    idea 创建运行web项目时,报错: Can not issue executeUpdate() for SELECTs解决方案
  • 原文地址:https://www.cnblogs.com/hezhiyao/p/13622073.html
Copyright © 2020-2023  润新知