线程之间的执行共享全局变量

首先我们要明白线程和进程的基本概念
进程:是并发执行的程序在执行过程中分配和管理资源的基本单位,是一个动态概念,竞争计算机系统资源的基本单位。
线程:是进程的一个执行单元,比进程更小的独立运行的基本单位,线程也被称为轻量级进程。
总结:没有进程就没有线程。

这篇文章不讲太过于详细二者的区别以及用法,我在这里就分享给大家一个二者的一个区别地方吧!
划重点!!!
线程共享全局变量,进程不共享全局变量

在这里我分享一个简短的代码来帮助大家理解,废话不多说,上代码!!!

import threading

list = [] # 创建一个全局变量
def write():
    for i in range(5):
        list.append(i)
    print(list)

def read():
    print("读取的数据是:",list)

if __name__ == '__main__':
    write_process = threading.Thread(target=write) # 创建写线程
    read_process = threading.Thread(target=read)  # 创建读线程
    write_process.start()
    write_process.join()  
    # 等待子线程执行完毕后执行下面的代码,目的在于守护子线程,
    #避免出现子线程还没执行完毕,主线程执行完毕然后然后销毁了子线程,
    #这点大家要重点理解一下,注意!write_process.join()只能写在start()后执行的代码的开头,位置不能变

    print("开始读取数据:")
    read_process.start()

这就是证明线程共享全局变量的代码,下面大家看一看执行结果看看两个函数的执行结果,对比一下看看是否真的是线程之间共享全局变量
结果!!!
在这里插入图片描述

很清楚看得出来write函数和read函数最终执行结果一样,read函数读出来的全局变量还只能是write函数执行的全局变量的结果,这也就有力的证明了线程之间共享全局变量这一结论!!!
Last重点来啦!!!
在这里插入图片描述
到此呢我们的知识分享也就告一段落了,如果你觉得作者写的内容还看的过去,或者还不赖的话,麻烦大家给作者点一个小小的关注,收藏一下就更好啦!作者也是一个小白初写博客,希望大家多多支持,大家的认可也是作者努力下去的动力,在此说一声谢谢!
相信善良的你肯定不会就这样离开的!!!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小熊佩萁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值