参见Raymond Hettinger-超级超级!-PyCon
2015,有关如何使用超级继承和多重继承而不是DI的争论。如果您没有时间观看整个视频,请跳至第15分钟(但我建议您观看所有视频)。
这是一个如何将此视频中的内容应用于您的示例的示例:
框架代码:
class TokenInterface(): def getUserFromToken(self, token): raise NotImplementedErrorclass frameworkClass(TokenInterface): def do_the_job(self, ...): # some stuff self.user = super().getUserFromToken(...)
客户代码:
class SQLUserFromToken(TokenInterface): def getUserFromToken(self, token): # load the user from the database return userclass ClientframeworkClass(frameworkClass, SQLUserFromToken): passframework_instance = ClientframeworkClass()framework_instance.do_the_job(...)
这将起作用,因为Python MRO将保证调用getUserFromToken客户端方法(如果使用了super())。如果您使用的是Python2.x,则必须更改代码。
此处的另一个好处是,如果客户端不提供实现,则会引发异常。
当然,这并不是真正的依赖注入,它是多个继承和混合,但这是解决问题的Python方法。



