我正在研究 Python 中的代理模式。我使用该方法正确代理了常规方法__getattr__
。但是,类方法失败。
class DBClass(object):
def aMethod(self):
print 'aMethod'
@classmethod
def aClassMethod(cls):
print 'aClassMethod'
class DBWrapper(object):
def __init__(self, db = None):
super(DBWrapper, self).__init__()
self._db = db
def __getattr__(self, name):
if not self._db:
raise Exception("DBWrapper: DB is not initialized yet!")
if hasattr(self._db, name):
return getattr(self._db, name)
else:
raise AttributeError(name)
class User(DBWrapper):
def uMethod(self):
print 'uMethod'
@classmethod
def userClassMethod(cls):
cls.aClassMethod()
db = DBClass()
user = User(db)
user.uMethod() #prints uMethod
user.aMethod() #prints aMethod
user.aClassMethod() #prints aClassMethod
user.userClassMethod() #Fails with AttributeError: type object 'User' has no attribute 'aClassMethod'
我知道这失败了,因为“用户”类定义没有关于 DBClass 的信息,而“用户”的实例有关于 DBClass 的信息。如何解决我在这里想要实现的目标?
附加说明:为简单起见,我删除了继承的某些其他方面。在实际实现中:
我有多个继承自 DBClass 的类
我有多个继承自 DBWrapper 的类
DBClass-Child 的一个实例是传递给 DBWrapper-Child 的构造函数的——类似于 User 类的实例化。
我无法控制 DBClass。它是图书馆的一部分,我无法更改它。