python 多线程共享全局变量的优劣
一、多线程共享全局变量
首先我们来回忆下在函数中修改全局变量的情况。
在一个函数中,对全局变量进行修改的时候,到底是否需要使用 global 进行说明,要看是否对全局变量的执行指向进行了修改。
如果修改了执行指向,即让全局变量指向了一个新的地方,那么必须使用 global。
如果仅仅是修改了指向的空间中的数据,此时不是必须要使用 global。
我们来看一个例子,在这个例子中,让一个子线程对全局变量 +1 操作,另一个子线程只打印全局变量,看看数据是否共享。
from threading import Thread import time g_num = 100 def work1(): global g_num g_num += 1 print("----in work1, g_num is %d---" % g_num) def work2(): print("----in work2, g_num is %d---" % g_num) def main(): print("---线程创建之前g_num is %d---" % g_num) t1 = Thread(target=work1) t1.start() # 延时一会,保证t1线程中的事情做完 time.sleep(1) t2 = Thread(target=work2) t2.start() time.sleep(1) print("---线程创建之后g_num is %d---" % g_num) if __name__ == "__main__": main()
如果子线程2打印出来的结果是100,说明全局变量不共享。
如果子线程2打印出来的数据是101,说明全局变量共享。
运行结果:
---线程创建之前g_num is 100---
----in work1, g_num is 101---
----in work2, g_num is 101---
---线程创建之后g_num is 101---
上面的例子说明,多线程是共享全局变量的。
二、列表当做实参传递到线程中
在上面,我们验证了多线程之间是共享全局变量的。
我们也可以将变量当作实参传递到线程中,来验证多线程中是共享数据的。
from threading import Thread import time def work1(nums): nums.append(44) print("----in work1---", nums) def work2(nums): print("----in work2---", nums) g_nums = [11, 22, 33] t1 = Thread(target=work1, args=(g_nums,)) t1.start() # 延时一会,保证t1线程中的事情做完 time.sleep(1) t2 = Thread(target=work2, args=(g_nums,)) t2.start()
运行结果:
----in work1--- [11, 22, 33, 44]
----in work2--- [11, 22, 33, 44]
那为什么多个线程之间要共享全局变量,有什么好处么?
因为多任务往往配合使用。
在一个进程内的所有线程共享全局变量,就可以很方便在多个线程间共享数据。
缺点就是,线程是对全局变量随意修改可能造成多线程之间对全局变量的混乱(即线程非安全)。
以上就是python 多线程共享全局变量的优劣的详细内容,更多关于python 多线程共享全局变量的资料请关注我们其它相关文章!
相关推荐
-
python 多进程共享全局变量之Manager()详解
Manager支持的类型有 list,dict,Namespace,Lock,RLock,Semaphore,BoundedSemaphore,Condition,Event,Queue,Value和Array. 但当使用Manager处理list.dict等可变数据类型时,需要注意一个陷阱,即Manager对象无法监测到它引用的可变对象值的修改,需要通过触发__setitem__方法来让它获得通知. 而触发__setitem__方法比较直接的办法就是增加一个中间变量,如同在C语言中交换两个变量
-
Python中的全局变量如何理解
Python是一种面向对象的开发语言,在函数中使用全局变量,一般应作全局变量说明,只有在函数内经过说明的全局变量才能使用. 首先应该说明的是需要尽量避免使用Python全局变量.不同的模块都可以自由的访问全局变量,可能会导致全局变量的不可预知性.对全局变量,如果程序员甲修改了_a的值,这时可能导致程序中的错误.这种错误是很难发现和更正的. 全局变量降低了函数或模块之间的通用性,不同的函数或模块都要依赖于全局变量.同样,全局变量降低了代码的可读性,阅读者可能并不知道调用的某个变量是全局变量. 但是
-
浅谈Python 多进程默认不能共享全局变量的问题
主进程与子进程是并发执行的,进程之间默认是不能共享全局变量的(子进程不能改变主进程中全局变量的值).如果要共享全局变量需要用(multiprocessing.Value("d",10.0),数值)(multiprocessing.Array("i",[1,2,3,4,5]),数组)(multiprocessing.Manager().dict(),字典)(multiprocessing.Manager().list(range(5))).进程通信(进程之间传递数据)
-
python进阶之多线程对同一个全局变量的处理方法
通常情况下: 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_num +=
-
python多进程 主进程和子进程间共享和不共享全局变量实例
Python 多进程默认不能共享全局变量 主进程与子进程是并发执行的,进程之间默认是不能共享全局变量的(子进程不能改变主进程中全局变量的值). 如果要共享全局变量需要用(multiprocessing.Value("d",10.0),数值)(multiprocessing.Array("i",[1,2,3,4,5]),数组)(multiprocessing.Manager().dict(),字典)(multiprocessing.Manager().list(ran
-
Python局部变量与全局变量区别原理解析
1.局部变量 name = "Yang Li" def change_name(name): print("before change:",name) name = "你好" print("after change", name) change_name(name) print("在外面看看name改了么?",name) 输出: before change: Yang Li after change 你好
-
python通过配置文件共享全局变量的实例
在使用Python编写的应用的过程中,有时会遇到多个文件之间传递同一个全局变量的情况,此时通过配置文件定义全局变量是一个比较好的选择. 首先配置config.py模块,config需要设置get_xxx和set_xxx的方法提供对外的接口. config.py class global_var: '''需要定义全局变量的放在这里,最好定义一个初始值''' name = 'my_name' # 对于每个全局变量,都需要定义get_value和set_value接口 def set_name(nam
-
Python global全局变量函数详解
global语句的作用 在编写程序的时候,如果想为一个在函数外的变量重新赋值,并且这个变量会作用于许多函数中时,就需要告诉python这个变量的作用域是全局变量.此时用global语句就可以变成这个任务,也就是说没有用global语句的情况下,是不能修改全局变量的. 在python的函数使用时,经常会碰到参数定义的问题.如果不声明全局变量,会报错 count = 1 def cc(): count = count+1 cc() Traceback (most recent call last):
-
Python 进程之间共享数据(全局变量)的方法
进程之间共享数据(数值型): import multiprocessing def func(num): num.value=10.78 #子进程改变数值的值,主进程跟着改变 if __name__=="__main__": num=multiprocessing.Value("d",10.0) # d表示数值,主进程与子进程共享这个value.(主进程与子进程都是用的同一个value) print(num.value) p=multiprocessing.Proc
-
python 多线程共享全局变量的优劣
一.多线程共享全局变量 首先我们来回忆下在函数中修改全局变量的情况. 在一个函数中,对全局变量进行修改的时候,到底是否需要使用 global 进行说明,要看是否对全局变量的执行指向进行了修改. 如果修改了执行指向,即让全局变量指向了一个新的地方,那么必须使用 global. 如果仅仅是修改了指向的空间中的数据,此时不是必须要使用 global. 我们来看一个例子,在这个例子中,让一个子线程对全局变量 +1 操作,另一个子线程只打印全局变量,看看数据是否共享. from threading imp
-
互斥锁解决 Python 中多线程共享全局变量的问题(推荐)
一.同步概念 同步就是协同步调,按预定的先后次序进行运行.如:你说完,我再说. "同"字从字面上容易理解为一起动作. 其实不是,在这里,"同"字应是指协同.协助.互相配合. 线程同步,可理解为线程A和B一块配合,A执行到一定程度时要依靠B的某个结果,于是停下来,示意B运行:B执行,再将结果给A:A再继续操作. 之前我们遇到过,如果多个线程共同对某个数据修改,则可能出现不可预料的结果,为了保证数据的正确性,需要对多个线程进行同步. 解决线程同时修改全局变量的方式 我们
-
Python多线程threading模块用法实例分析
本文实例讲述了Python多线程threading模块用法.分享给大家供大家参考,具体如下: 多线程 - threading python的thread模块是比较底层的模块,python的threading模块对thread做了一些包装,可以更加方便的被使用. 1. 使用threading模块 单线程执行 #coding=utf-8 import time def saySorry(): print('跑一圈') time.sleep(1) if __name__ == "__main__&qu
-
Python 多线程搜索txt文件的内容,并写入搜到的内容(Lock)方法
废话不多说,直接上代码吧! import threading import os class Find(threading.Thread): #搜索数据的线程类 def __init__(self,datalist,startIndex,endIndex,searchstr,savefile): #datalist要搜索的内容列表,startIndex列表搜索范围的开始下标,searchstr要搜索的内容 threading.Thread.__init__(self) self.datalist
-
Python 多线程共享变量的实现示例
多线程-共享全局变量 #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---&
-
python多线程超详细详解
python中的多线程是一个非常重要的知识点,今天为大家对多线程进行详细的说明,代码中的注释有多线程的知识点还有测试用的实例. import threading from threading import Lock,Thread import time,os ''' python多线程详解 什么是线程? 线程也叫轻量级进程,是操作系统能够进行运算调度的最小单位,它被包涵在进程之中,是进程中的实际运作单位. 线程自己不拥有系统资源,只拥有一点儿在运行中必不可少的资源,但它可与同属一个进程的其他线程
-
python 多线程实现多任务的方法示例
目录 1 多线程实现多任务 1.1 什么是线程? 1.2 一个程序实现多任务的方法 1.3 多线程的创建方式 1.3.1 创建threading.Thread对象 1.3.2 继承threading.Thread,并重写run 1.4 线程何时开启,何时结束 1.5 线程的 join() 方法 1.6 多线程共享全局变量出现的问题 1.7 互斥锁可以弥补部分线程安全问题.(互斥锁和GIL锁是不一样的东西!) 1.8 线程池ThreadPoolExecutor 1.8.1 创建线程池 1.8.2
-
python多线程互斥锁与死锁问题详解
目录 一.多线程共享全局变量 二.给线程加一把锁锁 三.死锁问题 总结 一.多线程共享全局变量 代码实现的功能: 创建work01与worker02函数,对全局变量进行加一操作创建main函数,生成两个线程,同时调用两个函数 代码如下: import threading result = 0 # 定义全局变量result def work1(num): global result for i in range(num): result += 1 print('------from work1--
-
浅谈python多线程和多线程变量共享问题介绍
1.demo 第一个代码是多线程的简单使用,编写了线程如何执行函数和类. import threading import time class ClassName(threading.Thread): """创建类,通过多线程执行""" def run(self): for i in range(5): print(i) time.sleep(1) def sing(): for i in range(1,11): print("唱歌第
随机推荐
- seaJs使用心得之exports与module.exports的区别实例分析
- 说说JSON和JSONP 也许你会豁然开朗
- Win2003云服务器或VPS网站程序池调整设置技巧
- jquery缓动swing liner控制动画过程不同时刻的速度
- 两种iOS调用系统发短信的方法
- js解决select下拉选不中问题
- Java 开发的几个注意点总结
- Android内存泄漏排查利器LeakCanary
- 拥有一个属于自己的javascript表单验证插件
- 详解java中finalize的实现与相应的执行过程
- Android 软键盘弹出时把原来布局顶上去的解决方法
- 编写高效jQuery代码的4个原则和5个技巧
- 详解Java注解的实现与使用方法
- jQuery 使用手册(四)
- jquery图片不完全按比例自动缩小的简单代码
- js模拟画笔效果
- Omi v1.0.2发布正式支持传递javascript表达式
- C++火车入轨算法的实现代码
- java遍历读取xml文件内容
- python实现监控linux性能及进程消耗性能的方法