一、多线程共享全局变量
首先我们来回忆下在函数中修改全局变量的情况。
在一个函数中,对全局变量进行修改的时候,到底是否需要使用 global 进行说明,要看是否对全局变量的执行指向进行了修改。
如果修改了执行指向,即让全局变量指向了一个新的地方,那么必须使用 global。
如果仅仅是修改了指向的空间中的数据,此时不是必须要使用 global。
我们来看一个例子,在这个例子中,让一个子线程对全局变量 +1 操作,另一个子线程只打印全局变量,看看数据是否共享。
from threading im
通常情况下:
from threading import Thread
global_num = 0
def func1():
global global_num
for i in range(1000000):
global_num += 1
print('---------func1:global_num=%s--------'%global_num)
def func2():
global global_num
for i in range(1000000):
global
多线程-共享全局变量
#coding=utf-8
from threading import Thread
import time
g_num = 100
def work1():
global g_num
for i in range(3):
g_num += 1
print("----in work1, g_num is %d---"%g_num)
def work2():
global g_num
print("----in work2, g_num is %d---"%