国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python中from module import * 的一個坑

2020-02-23 05:36:05
字體:
來源:轉載
供稿:網友

但還有另外一個問題 - 你以為你修改了某個變量,其實,被from module import *后的那個并沒有被更新,非常危險,因為程序有可能還可以正常運行, 只不過結果錯了,到了production才被發現就比較慘了。

舉個例子:

你定義了一些變量在base模塊中:

# reference data typeclass Demo: def __init__(self, name):  self.name = namedemo = Demo('Demo')# primitive typefoo = 1

然后在一個模塊中用from  module import 的方式讀它:

from base import *def read():    print 'reference data id: ' + str(id(demo))    print 'reference data value : ' + demo.name    print 'primitive data id: ' + str(id(foo))    print 'primitive data value: ' + str(foo)

在另外一個模塊中寫它:

import basedef write(): print "/nOriginal:" print "Original reference data id: " + str(id(base.demo)) base.demo.name = "Updated Demo" # this will reflect that change #base.demo = base.Demo("Updated Demo") # this won't relfect the change print "Original data id: " + str(id(base.foo)) base.foo = 1000 print "Original data id after assignment: " + str(id(base.foo))

然后先寫,后讀,看寫的內容是否有效:

import readimport writeprint "before write"read.read()write.write()print "/nafter write"read.read()

結論是沒有,原因是:

當你用from module import時,其實是copy了一份reference或者pointer,指向一份內存,var和module.var都指向同一份內存
當你修改module.var時,其實你是讓它指向了另外一份內存,此時var和module.var指向的是不同的內存
所以,雖然module.var的值變了,var還是指向原來那份內存,原來的值
這個對于object,比較容易理解,你可以直接修改object里的值,這個是有效的,但是當你指向另外一個object時就無效了。 對于primitive類型來講,其實也是一個道理,因為每次賦值,都是讓其指向一個不同的內存地址,而不是inplace修改已有的那份內存 -  這個很容易驗證:

In [1]: a = 10In [2]: id(a)Out[2]: 20429204In [3]: a = 100In [4]: id(a)Out[4]: 20430108

所以,建議是除非是一個quick and dirty的腳本,否則不要使用from module import *!

例子: https://github.com/baiyanhuang/blog/tree/master/arena/python/from_module_import

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 景洪市| 岳阳市| 永泰县| 高平市| 邹城市| 灵璧县| 定州市| 乳山市| 西林县| 吉木萨尔县| 石柱| 建平县| 连城县| 浦江县| 炎陵县| 蓝山县| 宁南县| 类乌齐县| 德令哈市| 乌鲁木齐市| 都江堰市| 金乡县| 饶河县| 平定县| 九龙县| 兴隆县| 宝鸡市| 分宜县| 新津县| 龙井市| 元阳县| 汽车| 香河县| 西华县| 浪卡子县| 合山市| 房产| 雅安市| 体育| 侯马市| 东山县|