鱼C论坛

 找回密码
 立即注册
查看: 925|回复: 9

[已解决]小甲鱼魔方方法疑问(教材12-7)

[复制链接]
发表于 2020-5-18 12:17:53 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. class MyProperty:
  2.     def __init__(self, fget=None, fset=None, fdel=None):
  3.         self.fget = fget
  4.         self.fset = fset
  5.         self.fdel = fdel

  6.     def __get__(self, instance, owner):
  7.         return self.fget(instance)

  8.     def __set__(self, instance, value):
  9.         self.fset(instance, value)

  10.     def __delete__(self, instance):
  11.         self.fdel(instance)

  12. class C:
  13.     def __init__(self):
  14.         self._x = None

  15.     def getX(self):
  16.         return self._x

  17.     def setX(self, value):
  18.         self._x = value

  19.     def delX(self):
  20.         del self._x

  21.     x = MyProperty(getX, setX, delX)

  22. c=C()
  23. c.x='X-man'
  24. print(c._x)
复制代码


疑问:在__get__方法中,返回的是self.fget(instance),也就是用‘方法名(实例名)’的方式访问C的实例方法,但访问实例方法应该用‘实例名.方法名()'的方式访问才对,把self.fget(instance)改为instance.(self.fget())运行会报错,为什么?
最佳答案
2020-5-18 12:39:00

看下这个对你有没帮助
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-5-18 12:22:05 | 显示全部楼层
在__get__方法中,返回的是self.fget(instance),也就是用‘方法名(实例名)’的方式访问C的实例方法,但访问实例方法应该用‘实例名.方法名()'的方式访问才对

self.fget(instance) 不是方法吧,是实例变量
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-18 12:39:00 | 显示全部楼层    本楼为最佳答案   

看下这个对你有没帮助
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-18 13:43:52 | 显示全部楼层
路过
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-5-18 14:57:51 | 显示全部楼层
Twilight6 发表于 2020-5-18 12:22
self.fget(instance) 不是方法吧,是实例变量

我觉得还是通过方法调用的,改为instance.getX()就能正常运行了,但改成instance.self.fget()就不能运行了,但在初始化时已经定义了self.fget=getX,应该是等价的啊。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-18 15:15:38 | 显示全部楼层
daisanosng 发表于 2020-5-18 14:57
我觉得还是通过方法调用的,改为instance.getX()就能正常运行了,但改成instance.self.fget()就不能运行 ...

self.fget是实例变量
你定义的 C类  是 MyProperty描述符类的拥有者
MyProperty 里面的 instance 就是代表着是C类, self代表是实例化对象  owner 是这个描述符类的本身
对应你的代码中__get__方法对应的参数:
  1. self 代表是 c 实例
  2. instance 代表着是 C 类
  3. owner 代表着是 MyProperty 描述符类
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-18 15:17:36 | 显示全部楼层
Twilight6 发表于 2020-5-18 12:39
看下这个对你有没帮助

如果类定义是下面这个;
  1. class CLanguage :
  2.     def __init__(self):
  3.         self.name = "C语言中文网"
  4.         self.add = "http://c.biancheng.net"
  5.     # 下面定义了一个say实例方法
  6.     def say(self):
  7.         self.catalog = 13
复制代码

  1. print(CLanguage.name)
复制代码

会报错,CLanguage没有name属性的,咋回事????????没有实例化吗?不懂
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-18 15:20:01 | 显示全部楼层
qiangqiang1 发表于 2020-5-18 15:17
如果类定义是下面这个;
  1. print(CLanguage().name)
复制代码

这样即可,直接的CLanguage是没有实例化的,而你访问的是实例变量name
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-18 15:20:52 | 显示全部楼层
qiangqiang1 发表于 2020-5-18 15:17
如果类定义是下面这个;
  1. class CLanguage :
  2.     x = 111
  3.     def __init__(self):
  4.         self.name = "C语言中文网"
  5.         self.add = "http://c.biancheng.net"
  6.     # 下面定义了一个say实例方法
  7.     def say(self):
  8.         self.catalog = 13
  9. print(CLanguage.x)
复制代码

这样只能访问类变量
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-19 16:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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