小甲鱼魔方方法疑问(教材12-7)
class MyProperty:def __init__(self, fget=None, fset=None, fdel=None):
self.fget = fget
self.fset = fset
self.fdel = fdel
def __get__(self, instance, owner):
return self.fget(instance)
def __set__(self, instance, value):
self.fset(instance, value)
def __delete__(self, instance):
self.fdel(instance)
class C:
def __init__(self):
self._x = None
def getX(self):
return self._x
def setX(self, value):
self._x = value
def delX(self):
del self._x
x = MyProperty(getX, setX, delX)
c=C()
c.x='X-man'
print(c._x)
疑问:在__get__方法中,返回的是self.fget(instance),也就是用‘方法名(实例名)’的方式访问C的实例方法,但访问实例方法应该用‘实例名.方法名()'的方式访问才对,把self.fget(instance)改为instance.(self.fget())运行会报错,为什么? 在__get__方法中,返回的是self.fget(instance),也就是用‘方法名(实例名)’的方式访问C的实例方法,但访问实例方法应该用‘实例名.方法名()'的方式访问才对
self.fget(instance) 不是方法吧,是实例变量 文档:类、实例、局部变量
http://note.youdao.com/noteshare?id=d121373edf297b4601ba697ad8e220ea&sub=02ACF9322A2B4E619E7E6F44BD603893
看下这个对你有没帮助 路过 Twilight6 发表于 2020-5-18 12:22
self.fget(instance) 不是方法吧,是实例变量
我觉得还是通过方法调用的,改为instance.getX()就能正常运行了,但改成instance.self.fget()就不能运行了,但在初始化时已经定义了self.fget=getX,应该是等价的啊。 daisanosng 发表于 2020-5-18 14:57
我觉得还是通过方法调用的,改为instance.getX()就能正常运行了,但改成instance.self.fget()就不能运行 ...
self.fget是实例变量
你定义的 C类是 MyProperty描述符类的拥有者
MyProperty 里面的 instance 就是代表着是C类, self代表是实例化对象owner 是这个描述符类的本身
对应你的代码中__get__方法对应的参数:
self 代表是 c 实例
instance 代表着是 C 类
owner 代表着是 MyProperty 描述符类 Twilight6 发表于 2020-5-18 12:39
看下这个对你有没帮助
如果类定义是下面这个;
class CLanguage :
def __init__(self):
self.name = "C语言中文网"
self.add = "http://c.biancheng.net"
# 下面定义了一个say实例方法
def say(self):
self.catalog = 13
print(CLanguage.name)
会报错,CLanguage没有name属性的,咋回事????????没有实例化吗?不懂 qiangqiang1 发表于 2020-5-18 15:17
如果类定义是下面这个;
print(CLanguage().name)
这样即可,直接的CLanguage是没有实例化的,而你访问的是实例变量name qiangqiang1 发表于 2020-5-18 15:17
如果类定义是下面这个;
class CLanguage :
x = 111
def __init__(self):
self.name = "C语言中文网"
self.add = "http://c.biancheng.net"
# 下面定义了一个say实例方法
def say(self):
self.catalog = 13
print(CLanguage.x)
这样只能访问类变量
页:
[1]