Python中全局變量的引用與修改之格式影響


先來看下面的代碼及執行結果:

a = 1
b = [2,3]
def nums():
    a = 2
    b[0] = 0
    print(a)
    print(b)
print(a)
print(b)
nums()
print(a)
print(b)

結果:

1
[2, 3]
2
[0, 3]
1
[0, 3]

對上面結果的分析:

  函數 nums() 中重新定義了一個變量 a ,這個 a 是局部變量,與外面的全局變量沒有關系,而全局變量 列表 b 直接被引用過來進行修改了,同樣是全局變量為什么會有差別呢?

  因為格式問題引發了歧義,容器類型的數據如,列表,字典,他們的修改和創建書寫格式全然不同,不會引發奇異,而數字,字符串類型變量的定義和修改都是用 = 鏈接,引發了格式上的歧義,所以,當Python解釋器遇到函數中的 “a = 2”這種格式時,不知道是  “引用全局變量a修改為2”  還是  “定義一個等於 2 的變量”  ,從而引發歧義,為了確保全局變量對代碼其他部分產生更小的影響,Python默認為第二種——重新定義一個變量,來避免修改全局變量對整體代碼產生其他未知影響。

綜上所述:

  本質:格式引發的歧義問題

  運用:對於字典,列表不會因為格式問題引發歧義的,不用管他;對於數字,字符串來說,當引用與創建發生歧義時,Python解釋器默認創建新的變量,若不想創建,只是想修改全局變量,需要加global聲明,另外,如果只是單純的引用全局變量,而不會產生歧義的,如 對於全局變量 a 來說,b = a + 5,這里只是單純的使用,不會產生格式上的歧義問題,也不需要加global。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM