Python 中多线程共享全局变量的问题(1),Python开发知识点

本文探讨了Python中多线程环境下共享全局变量可能导致的问题,通过示例展示了两个线程对同一全局变量进行操作后,结果可能出现非预期的情况。文章指出,当数据量增大时,线程同步问题更为明显,并提供了确保子线程执行完毕的示例代码。作者还分享了丰富的Python学习资源,包括学习路线、视频教程、项目实践、电子书等。
摘要由CSDN通过智能技术生成

运行结果:

—线程创建之前g_num is 0—

----in work1, g_num is 100—

----in work2, g_num is 200—

2个线程对同一个全局变量操作之后的最终结果是:200

乍一看,好像没出什么问题。那是因为数据太小了,我们现在把数据变大。

‘’’

遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939

寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!

‘’’

import threading

import time

g_num = 0

def work1(num):

global g_num

for i in range(num):

g_num += 1

print(“----in work1, g_num is %d—” % g_num)

def work2(num):

global g_num

for i in range(num):

g_num += 1

print(“----in work2, g_num is %d—” % g_num)

print(“—线程创建之前g_num is %d—” % g_num)

t1 = threading.Thread(target=work1, args=(1000000,))

t1.start()

t2 = threading.Thread(target=work2, args=(1000000,))

t2.start()

确保子线程都运行结束

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值