前言:好的,昨天呢我们讨论了关于线程执行时是共享全局变量的,可是这样也就会产生一个问题,就是既然全局变量被共享,而且线程的执行又是无序的,所以有时候就会产生数据出错的问题
这样说大家肯定云里雾里,不太明白,下面我通过代码来进行解释,废话不多说,上代码!!!
首先我们用sun_num_thread.join()放在sun_num2_thread.start()前面,目的在于解决线程执行无序的问题,让第一个函数先执行,然后再执行第二个函数,这样就保证了执行结果的准确性
import threading
# 创建函数,实现循环一百万次,每次给全局变量加一
import time
g_num = 0
# 每次给全局变量加1
def sun_num():
for i in range(1000000):
global g_num
g_num += 1
print("sum_num:",g_num)
# 每次给全局变量加1
def sun_num2():
for i in range(1000000):
global g_num
g_num += 1
print("sum_num2:",g_num)
if __name__ == '__main__':
#创建子线程
sun_num_thread = threading.Thread(target=sun_num)
sun_num2_thread = threading.Thread(target=sun_num2)
#启动子线程
sun_num_thread.start()
sun_num_thread.join()
sun_num2_thread.start()
结果展示:
结果没问题,第二个函数在第一个函数的结果基础上又加了1000000,没有出现结果的错误。
可是当没有守护方法呢,这样线程就又是无序的并发执行了
看代码!!!
import threading
# 创建函数,实现循环一百万次,每次给全局变量加一
import time
g_num = 0
# 每次给全局变量加1
def sun_num():
for i in range(1000000):
global g_num
g_num += 1
print("sum_num:",g_num)
# 每次给全局变量加1
def sun_num2():
for i in range(1000000):
global g_num
g_num += 1
print("sum_num2:",g_num)
if __name__ == '__main__':
#创建子线程
sun_num_thread = threading.Thread(target=sun_num)
sun_num2_thread = threading.Thread(target=sun_num2)
#启动子线程
sun_num_thread.start()
#sun_num_thread.join()
sun_num2_thread.start()
结果展示:
这是同一个代码执行多次的结果,每次执行后都不一样,这就是数据出现了错误和混乱,所以我们在使用多线程共享全局变量时这个问题一定不能忽视!!!
LAST重点来了!!!
ps:到此我们的知识分享也就告一段落了,如果你觉得作者写的内容还看的过去,或者还不赖的话,麻烦大家给作者点一个小小的关注,收藏一下就更好啦!作者也是一个小白初写博客,希望大家多多支持,大家的认可也是作者努力下去的动力,在此说一声谢谢!