我們以一個例子展開這個題目
問題:
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