1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > Python设计模式编程中的访问者与观察者模式示例介绍

Python设计模式编程中的访问者与观察者模式示例介绍

时间:2020-01-16 21:34:11

相关推荐

Python设计模式编程中的访问者与观察者模式示例介绍

后端开发|Python教程

Python,设计模式

后端开发-Python教程访问者模式

我觉得Visitor模式是在补修改已有程序结构前提下,通过添加额外的访问者完成对代码功能的拓展 为什么这样用?当你的类层次较多,在某层结构中增加新的方法,要是在基类上面添加或者变更,可能破坏原来的设计, 有兼容问题,所以只在需要的类上面动态添加。

影视系统源码带电影下载功能,ubuntu下更新命令,b站爬虫接口,php.session,嘉啉seolzw

python的例子

这里是个构建车的例子,每个部件都有一个accept的方法接受我上面说的所谓’访问者’,而这个访问者 以参数的方式传进来,但是其实他是一个含有一些功能的类的实例,它拥有很多个visit开头的方法对应不同的部件。 这样就不需要修改这些部件,而只是修改我们的访问者类的相关部分。

资源免费分享精品源码,vscode阿里代码规范,迅雷ubuntu运行,tomcat主页漏洞,sqlite用于配置文件,爬虫爬取腾讯新闻网站,微信机器人 php,广州头条seo优化,网站图片下载 代码,网页红包互换源码,magento中文模板lzw

网页qq聊天源码,vscode皮肤,ubuntu php,tomcat绑定域名,安卓与sqlite,东胜网页设计,mysql数据库修改索引,ftp服务器登录不上,share插件,前端框架主流,美团 爬虫,php语句,长沙seo,springboot数据源配置,dede图集标签,织梦网站每天首页都有隐藏的外链 怎么解决,js表格控件在网页中如何使用,仿ebay模板,aspcms后台添加教程,jq 页面往下滚动,游乐场管理系统源码,2345网址导航程序lzw

# 轮子,引擎, 车身这些定义好了都不需要变动class Wheel: def init(self, name): self.name = name def accept(self, visitor): # 每个visitor是同样的,但是其中的方法是不一样的,比如这里是visitWheel, # 然后传入了self,想想?他其实想做什么就能做什么 visitor.visitWheel(self)class Engine: def accept(self, visitor): visitor.visitEngine(self)class Body: def accept(self, visitor): visitor.visitBody(self)# 我们要组合成车class Car: def init(self): self.engine = Engine() self.body = Body() self.wheels = [ Wheel("front left"), Wheel("front right"), Wheel("back left") , Wheel("back right") ] # 这个也不需要在动,他只是上面部件的组合,只是做了属性的委托 def accept(self,visitor): visitor.visitCar(self) self.engine.accept(visitor) self.body.accept(visitor) for wheel in self.wheels:wheel.accept(visitor)# 这个才是我们的访问者,每次的修改都在这里面class PrintVisitor: def visitWheel(self, wheel): print "Visiting "+wheel.name+" wheel" def visitEngine(self, engine): print "Visiting engine" def visitBody(self, body): print "Visiting body" def visitCar(self, car): print "Visiting car"if name == main: car = Car() visitor = PrintVisitor() car.accept(visitor)

观察者模式

当我们希望一个对象的状态发生变化,那么依赖与它的所有对象都能相应变化(获得通知),那么就可以用到Observer模式, 其中的这些依赖对象就是观察者的对象,那个要发生变化的对象就是所谓’观察者’

python的例子

# 这个是观察者基类class Subject(object): def init(self): self._observers = [] # 添加依赖的对象 def attach(self, observer): if not observer in self._observers:self._observers.append(observer) # 取消添加 def detach(self, observer): try:self._observers.remove(observer) except ValueError:pass # 这里只是通知上面注册的依赖对象新的变化 def notify(self, modifier=None): for observer in self._observers:# 可以设置过滤条件,对不符合过滤条件的更新if modifier != observer: observer.update(self)# 观察者类class Data(Subject): def init(self, name=\): super(Data, self).init() self.name = name self._data = 0 # python2.6新增的写法,获取属性为property,设置属性为(假设属性名字为x)@x.setter,删除为@x.deleter @property def data(self): return self._data @data.setter def data(self, value): self._data = value self.notify()# 这里有2个被观察者,也就是依赖的对象,每次Data有改变,这2个view都会变动class HexViewer(object): def update(self, subject): print HexViewer: Subject %s has data 0x%x % (subject.name, subject.data)class DecimalViewer(object): def update(self, subject): print DecimalViewer: Subject %s has data %d % (subject.name, subject.data)if name == main: data1 = Data(Data 1) data2 = Data(Data 2) view1 = DecimalViewer() view2 = HexViewer() data1.attach(view1) data1.attach(view2) data2.attach(view2) data2.attach(view1) print "Setting Data 1 = 10" data1.data = 10 print "Setting Data 2 = 15" data2.data = 15 print "Setting Data 1 = 3" data1.data = 3 print "Setting Data 2 = 5" data2.data = 5 print "Update data1s view2 Because view1 is be filtered" data1.notify(modifier=view1) print "Detach HexViewer from data1 and data2." data1.detach(view2) data2.detach(view2) print "Setting Data 1 = 10" data1.data = 10 print "Setting Data 2 = 15" data2.data = 15

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。