python导入函数模块 为什么会打印两次_python 模块会导入几次?猴子补丁为什么可以实现?...

一共三个文件

a.py内容是

print(‘被导入‘)

x = 1

b.py内容是

import a

a.x = 2

c.py内容是

import a

import b

print(a.x)

现在运行c文件,这个结果出乎很多人的意料大部分python人员都猜不对,结果是

3140fc3165f3ddbb56048479a5381d23.png

1、可以发现a模块被两个地方导入了,但是只打印一次 “被导入”。

2、在c文件里面不管是先导入a还是导入b,打印x的结果都是2。

不光是自己的文件如此,导入库文件也是一样。所以这就是猴子补丁能实现的原因。

2、再多想一下,为什么要面向对象了,不面向对象,直接模块加全局变量,会造成多个地方全局变量互相干扰。有了类,类天然就是多实例,类的所有实例就像是无数个全局变量互不干扰的复制模块。

2.1不用面向对象也可以实现多实例,原来是狗写成全局变量了,需要改成从函数return一只狗,然后有个吃翔的函数,把这个return出来的狗传给这个函数,所以形式是

eat(dog,sheet)

2.2用面向对象,那么就不是狗模块了,有个狗类,狗吃翔变成了

dog = Dog()

dog.eat(sheeet)

那么多个狗就实例化多次,每个狗 吃了多少翔  体重变化了多少,都是完全独立的。

2.1的面向过程模拟多实例,需要在类外传入和保存很多狗的属性和状态,多个函数使用同一个类型的传参,很频繁,不是很容易看懂,例如a函数的第一个参数和b函数的第一个参数是代表同一个东西比如狗的名字,有的人在a函数写dog_name,在b

函数写name,真的不容易看出来他们的关联。如果是面向对象,那是很直观的,a方法和b方法都是引用self.name。

扯远了从模块导入机制  到了猴子补丁 面向过程 面向对象了。

原文:https://www.cnblogs.com/ydf0509/p/9366062.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值