我们以一个例子展开这个题目
问题:
python类对象A,先实例化一个A对象的实例b,接着给A对象添加一个类共享变量xxx,再实例化一个c,请问b 和c都有变量xxx吗
解答:
python类共享变量,是不需要实例化就可以调用的, 比如类A有一个XXX的类共享变量, 直接A.xxx就可以调用
第一步:b在实例化的时候类A中没有共享变量xxx,这个时候实例b是没有这个变量
第二步:给类A 添加一个类共享变量XXX, 添加完成后,会自动给类A 已生成的实例添加变量XXX ,所以b实例在A添加共享变量XXX后,也会有变量XXX
第三步:最后实例化c的时候类A本来已经有类共享变量xxx,所以c实例也会有变量xxx
结论:实例b c都会有变量xxx
写段代码验证下
1
2
3
4
5
6
7
8
9
10
|
#coding=utf-8
class A():
pass
b = A()
print ( dir (b), "b实例 ,共享变量添加前" )
A.xxx = 10
c = A()
print ( dir (b), "b实例 ,共享变量添加后" )
print ( dir (c), "b实例 " )
|
代码执行结果
根据结果看, 可以看出添加类共享变量xxx之后 ,b c 实例都有变量xxx
补充知识:PYTHON多模块文件共享变量
首先,有5个Python文件,共享变量x存在glovar.py里面,需要在任意模块都能更改,更改后任意模块获取到的值都相同,这就是多模块文件共享一个变量。
1
2
3
4
5
6
7
|
#5个文件的路径
c:\test\main.py
c:\test\show.py
c:\test\test.py
c:\test\common\__init__.py #空文件
c:\test\common\glovar.py
c:\test\common\calc.py
|
#glovar.py
x = 1
1
2
3
4
5
6
7
8
|
#show.py
from comon import glovar
class Show:
def showchange( self ):
if glovar.x! = 1 :
print 'show x change'
else :
print 'show x=1'
|
1
2
3
4
5
6
7
8
|
#test.py
from comon.glovar import x
class Test:
def testchange( self ):
if x! = 1 :
print 'test x change'
else :
print 'test x=1'
|
1
2
3
4
5
|
#calc.py
import glovar
class Calc:
def add( self ):
glovar.x + = 1
|
1
2
3
4
5
6
7
8
9
10
11
|
#main.py
from comon import glovar
c = Calc()
c.add()
s = Show()
s.showchange()
t = Test()
t.testchange()
|
运行main.py
1
2
3
|
#输出
show x change
test x = 1
|
上面这些文件,除了test.py失败,其他文件都能共享变量能成功,是因为python的命名空间相同,靠的就是import用正确
来看看这三种不同
1
2
3
|
import glovar
from comon import glovar
from common.glovar import x
|
Python import 包的机制是,import进来的和默认的系统的module了,都放在sys.module这个字典里面. 多个py文件再次import的时候,会先去sys.module里面检查是否已经import了,如果已经import了,就不再重复import,否则就import进来
===
import glovar和from comon import glovar的命名空间是一样的,key都是glovar
from common.glovar import x 则不一样,test.py中这样from import,就相当于在test.py文件中写了一行代码x = 1,
此时x就是test自己命名空间中的变量。所以x只在test.py中有效,无聊自己如何对x修改,都无法影响glovar 中的x
1
2
3
4
5
6
7
|
#换种说法
from glovar import x
#等同于
improt glovar
x = glovar.x
#你调用x的时候,就是自己的命名空间中的x
#当你执行x=2时,完全影响不到glovar.x
|
下面是解释
1
2
3
4
5
6
7
8
|
#引入当前glovar文件,此时namespace是glovar
import glovar
#从common目录中引入glovar,此时namespace是glovar
from comon import glovar
#从common目录中的glovar文件中引入x=1,此时namespace就是引用者,也就是上面的test.py
from common.glovar import x
|
所以,如果需要共享变量,就不要使用from file import x这种形式,而是使用import file,然后就可以通过file.x来使用,然后file.x='abc'可以进行修改。这样都这样处理全局性的变量就可以共享的。也就是保持一个独立的namespace,这样python不会再次导入,从而实现共享。
以上这篇python类共享变量操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/test_xhz/article/details/82110019