我的基类是一个Agent类,它有3个抽象方法:
class Agent():__Metaclass__ = abc.ABCMeta def __init__(self): @abc.abstractmethod def bIDding_curve(self): @abc.abstractmethod def evaluate_bIDding_curve(self): @abc.abstractmethod def action(self):
可以使用可执行文件(dymo)或使用FMU(C源代码的zip文件)来模拟代理.因此,我创建了两种不同类型的代理,这些代理从基础代理继承并实现与模拟通信的方式.这是dymo仿真环境的实现,但FMU也是如此.
class DymoAgent(Agent): def __init__(self,power,dymo): """ Agent based on the dymosim simulation environment. @param dymo: The dymo that needs to be run """ super(DymoAgent,self).__init__() self.dymo = dymo def bIDding_curve(self): pass def evaluate_bIDding_curve(self,priority): pass def action(self,priority): self.dymo.action()
DymoAgent和FMUAgent确定我的代理如何与模拟环境交互.
接下来,我需要代理的实现来确定代理如何与应用程序交互.但是,我希望这种交互独立于模拟环境.例如.我想创建一个可以与Heater应用程序通信的代理,并实现这样做的逻辑.
class Heater(WhatAgentShouldIUseHere): pass
我希望这个Heater类能够实现Agent基类的抽象方法以及Dymo或FMUAgent的实现,因此它知道如何与模拟进行交互.但我不想用从不同的模拟代理继承的相同逻辑(因此基本相同的代码)编写2个Heater类.我在这张图片中总结了这个问题:
有没有办法使用继承来防止这种情况?
/ Arnout
解决方法 Make Heater是一个简单的对象,它在构造函数中接受一个代理:class Heater(object): def __init__(self,agent): self.agent = agent # define other methods for interaction with Heater application # in which you can access agent methods like self.agent.a_method(...)总结
以上是内存溢出为你收集整理的Python双继承全部内容,希望文章能够帮你解决Python双继承所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)