1

我正在研究 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。它是图书馆的一部分,我无法更改它。

4

0 回答 0