鱼C论坛

 找回密码
 立即注册
查看: 1614|回复: 6

[已解决]第45讲课后题第二题 getattrbute重复出现46次的奇怪bug

[复制链接]
发表于 2019-8-14 11:11:51 | 显示全部楼层 |阅读模式
50鱼币
本帖最后由 yumjang 于 2019-8-16 21:29 编辑

问题如下:
在不上机验证的情况下,你能推断以下代码分别会显示什么吗??
>>> class C:
        def __getattr__(self, name):
                print(1)
        def __getattribute__(self, name):
                print(2)
        def __setattr__(self, name, value):
                print(3)
        def __delattr__(self, name):
                print(4)           
>>> c = C()
>>> c.x = 1
# 位置一,请问这里会显示什么?
>>> print(c.x)
# 位置二,请问这里会显示什么?



答案是:
3
2
None


而我的程序跑出来,在None之后会多46个2,即便把小甲鱼的代码直接放进去跑,也是多46个执行__getattribute__的结果。非常的奇怪。

我单独尝试以下代码,输入c = C()后getattribute也会重复出现,虽然把c实例化逻辑上不应该调用getattribute....
class C:
        def __getattr__(self, name):
                print("getattr")
        def __getattribute__(self, name):
                print("getattribute")
                return super().__getattribute__(name)
        def __setattr__(self, name, value):
                print("setattr")
                return super().__setattr__(name, value)
        def __delattr__(self, name):
                print("delattr")

我把代码发给别人,没问题,但我自己这儿却总是出现这鬼现象。求大神告知为啥...
最佳答案
2019-8-14 11:11:52
emmm,首先代码并没有问题,其次你要看不同版本汇编器的特性,不同版本可能会出现兼容冲突
我偶尔会遇到

最佳答案

查看完整内容

emmm,首先代码并没有问题,其次你要看不同版本汇编器的特性,不同版本可能会出现兼容冲突 我偶尔会遇到
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-8-14 11:11:52 | 显示全部楼层    本楼为最佳答案   
emmm,首先代码并没有问题,其次你要看不同版本汇编器的特性,不同版本可能会出现兼容冲突
我偶尔会遇到
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-8-14 11:38:52 | 显示全部楼层
我是 Python 3.7.4,运行你的代码结果如下:
setattr
getattribute
1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-8-14 18:16:23 | 显示全部楼层
Python 3.7.3 (v3.7.3:ef4ec6ed12, Mar 25 2019, 22:22:05) [MSC v.1916 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license()" for more information.
>>> class C:
        def __getattr__(self, name):
                print(1)
        def __getattribute__(self, name):
                print(2)
        def __setattr__(self, name, value):
                print(3)
        def __delattr__(self, name):
                print(4)

                
>>> c=C()
>>> c.x=1
3
>>> print(c.x)
2
None
>>> class C:
        def __getattr__(self, name):
                print("getattr")
        def __getattribute__(self, name):
                print("getattribute")
                return super().__getattribute__(name)
        def __setattr__(self, name, value):
                print("setattr")
                return super().__setattr__(name, value)
        def __delattr__(self, name):
                print("delattr")

                
>>> c=C()
>>> c.x=1
setattr
>>> print(c.x)
getattribute
1
和楼上一样,
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-8-14 18:45:08 | 显示全部楼层
但是很奇怪,我用的 Pycharm,直接在文件中编写代码运行结果是:
setattr
getattribute
1
而在 Pycharm 的 Python Console 中编写代码运行会出现很多 getattribute,这就不知道是怎么回事了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-8-14 19:31:07 | 显示全部楼层
zltzlt 发表于 2019-8-14 18:45
但是很奇怪,我用的 Pycharm,直接在文件中编写代码运行结果是:

而在 Pycharm 的 Python Console 中编 ...

不很知道,我在IDLE中的运行结果始终都是
setattr
getattribute
1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-8-15 10:03:06 | 显示全部楼层
zltzlt 发表于 2019-8-14 18:45
但是很奇怪,我用的 Pycharm,直接在文件中编写代码运行结果是:

而在 Pycharm 的 Python Console 中编 ...

Python Console 使用 IPython,可能是解释器问题
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-26 12:36

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表