我们以一个例子展开这个题目

问题:

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

写段代码验证下

#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实例 ")

代码执行结果

python类共享变量操作

根据结果看, 可以看出添加类共享变量xxx之后 ,b c 实例都有变量xxx

补充知识:PYTHON多模块文件共享变量

首先,有5个Python文件,共享变量x存在glovar.py里面,需要在任意模块都能更改,更改后任意模块获取到的值都相同,这就是多模块文件共享一个变量。

#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

#show.py
from comon import glovar
class Show:
 def showchange(self):
  if glovar.x!=1:
   print 'show x change'
  else:
   print 'show x=1'
#test.py
from comon.glovar import x
class Test:
 def testchange(self):
  if x!=1:
   print 'test x change'
  else:
   print 'test x=1'
#calc.py
import glovar
class Calc:
 def add(self):
  glovar.x+=1
#main.py
from comon import glovar
 
c = Calc()
c.add()
 
s = Show()
s.showchange()
 
t = Test()
t.testchange()

运行main.py

#输出
show x change
test x=1

上面这些文件,除了test.py失败,其他文件都能共享变量能成功,是因为python的命名空间相同,靠的就是import用正确

来看看这三种不同

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

#换种说法
from glovar import x
#等同于
improt glovar
x= glovar.x
#你调用x的时候,就是自己的命名空间中的x
#当你执行x=2时,完全影响不到glovar.x

下面是解释

#引入当前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类共享变量操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。