访问者模式
意义:
定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。TemplateMethod 使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
举例:
class Finance(object):
#财务数据结构类
def __init__(self):
self.salesvolume = None # 销售额
self.cost = None # 成本
self.history_salesvolume = None # 历史销售额
self.history_cost = None # 历史成本
def set_salesvolume(self, value):
self.salesvolume = value
def set_cost(self, value):
self.cost = value
def set_history_salesvolume(self, value):
self.history_salesvolume = value
def set_history_cost(self, value):
self.history_cost = value
def accept(self, visitor):
pass
class Finance_year(Finance):
#2018年财务数据类
def __init__(self, year):
Finance.__init__(self)
self.work = [] # 安排工作人员列表
self.year = year
def add_work(self, work):
self.work.append(work)
def accept(self):
for obj in self.work:
obj.visit(self)
class Accounting(object):
#会计类
def __init__(self):
self.ID = "会计"
self.Duty = "计算报表"
def visit(self, table):
print(f'会计年度: {table.year}')
print(f"我的身份是: {self.ID} 职责: {self.Duty}")
print(f'本年度纯利润: {table.salesvolume - table.cost}')
print('------------------')
class Audit(object):
#财务总监类
def __init__(self):
self.ID = "财务总监"
self.Duty = "分析业绩"
def visit(self, table):
print(f'会计总监年度: {table.year}')
print(f"我的身份是: {self.ID} 职责: {self.Duty}")
if table.salesvolume - table.cost > table.history_salesvolume - table.history_cost:
msg = "较同期上涨"
else:
msg = "较同期下跌"
print(f'本年度公司业绩: {msg}')
print('------------------')
class Adviser(object):
#战略顾问
def __init__(self):
self.ID = "战略顾问"
self.Duty = "制定明年战略"
def visit(self, table):
print(f'战略顾问年度: {table.year}')
print(f"我的身份是: {self.ID} 职责: {self.Duty}")
if table.salesvolume > table.history_salesvolume:
msg = "行业上行,扩大生产规模"
else:
msg = "行业下行,减小生产规模"
print(f'本年度公司业绩: {msg}')
print('------------------')
class Work(object):
#工作类
def __init__(self):
self.works = [] # 需要处理的年度数据列表
def add_work(self, obj):
self.works.append(obj)
def remove_work(self, obj):
self.works.remove(obj)
def visit(self):
for obj in self.works:
obj.accept()
if __name__ == '__main__':
work = Work() # 计划安排财务、总监、顾问对2018年数据处理
# 实例化2018年数据结构
finance_2018 = Finance_year(2018)
finance_2018.set_salesvolume(200)
finance_2018.set_cost(100)
finance_2018.set_history_salesvolume(180)
finance_2018.set_history_cost(90)
accounting = Accounting() # 实例化会计
audit = Audit() # 实例化总监
adviser = Adviser() # 实例化顾问
finance_2018.add_work(accounting) # 会计安排到2018分析日程中
finance_2018.add_work(audit) # 总监安排到2018分析日程中
finance_2018.add_work(adviser) # 顾问安排到2018分析日程中
work.add_work(finance_2018) # 添加2018年财务工作安排
work.visit()
输出结果:
会计年度: 2018
我的身份是: 会计 职责: 计算报表
本年度纯利润: 100
------------------
会计总监年度: 2018
我的身份是: 财务总监 职责: 分析业绩
本年度公司业绩: 较同期上涨
------------------
战略顾问年度: 2018
我的身份是: 战略顾问 职责: 制定明年战略
本年度公司业绩: 行业上行,扩大生产规模
------------------