1.代码是很基础的,自定义一个描述符中执行过程不理解,望高手解答!!!
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)
3.执行:
c=C()
c.x='X-man'
3.问题描述:
在执行c.x='X-man'后,此时self.fset = setX,则self.fset(instance,value)实际等同于setX(c,'X-man'),这样也能运行吗?不是应该是c.setX('X-man')吗?
class A:
def qiu2(self,y):
print('调用了qiu2')
return y*y
def qiu1(self,x):
print(x(self,5)) ##此处为疑惑点
执行
a=A()
a.qiu1(qiu2)
Traceback (most recent call last):
File "", line 1, in
a.qiu1(qiu2)
NameError: name 'qiu2' is not defined
#####按照大家的解答,x = qiu2 , 那x(self,5)应该也能调用成功的,可是会报错。然后将疑惑点改成print(self.x(5))运行仍然会出错,错误仍然是'qiu2'没有定义。为什么之前的代码能实现,而此处行不通呢?困扰几天了,希望大神能解答。
setX虽然从形参的角度使用时应该是setX(c,'X-man'),但是都是写成c.setX('X-man')这样的写法,这是等价的。
以魔法方法__get__为例,解释一下其内部参数:
__get__(self, instance, owner),查看行为发生时自动执行。其中:
self也就是该描述符类的实例对象自己,上例中为c;
instance表示类(上例温度类,非描述符类)的实例对象,例如t = Temperature,那么这个t就是instance;
owner就表示Temperature这个类。
而魔法方法__set__:
__set__(self, instance, value)
也是一样,不同的value代表赋值行为发生时,如上例t.c = 50,等号右端的值50。
所以,self.fset(instance,value)其实等价setX(c,'X-man')