


Introduction to visitor and observer pattern examples in Python design pattern programming
This article mainly introduces the visitor and observer pattern in PythonDesign PatternProgramming, and the formulation of the design pattern It is conducive to the coordination of team collaboration programming code. Friends who need it can refer to
Visitor mode
I think the Visitor mode is to modify the existing program. Under the premise of structure, why is it used to expand the function of the code by adding additional visitors? When you have many classes and add new methods to a certain layer of structure, if you add or change the base class, it may destroy the original design and cause compatibility issues, so only add it dynamically to the required classes.
Python example
Here is an example of building a car. Each component has an accept method to accept the so-called 'visitor' I mentioned above, and this visitor is passed in as a parameter. But in fact, it is an instance of a class that contains some functions. It has many methods starting with visit corresponding to different components. This way there is no need to modify these components, only the relevant parts of our visitor class.
# 轮子,引擎, 车身这些定义好了都不需要变动 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 pattern
When we want the state of an object If a change occurs, then the dependency and all its objects can change accordingly (get notified), then the Observer pattern can be used, in which these dependent objects are the objects of the observer, and the object that is to change is the so-called 'observer'
python example
# 这个是观察者基类 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 data1's 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
The above is the detailed content of Introduction to visitor and observer pattern examples in Python design pattern programming. For more information, please follow other related articles on the PHP Chinese website!

ThedifferencebetweenaforloopandawhileloopinPythonisthataforloopisusedwhenthenumberofiterationsisknowninadvance,whileawhileloopisusedwhenaconditionneedstobecheckedrepeatedlywithoutknowingthenumberofiterations.1)Forloopsareidealforiteratingoversequence

In Python, for loops are suitable for cases where the number of iterations is known, while loops are suitable for cases where the number of iterations is unknown and more control is required. 1) For loops are suitable for traversing sequences, such as lists, strings, etc., with concise and Pythonic code. 2) While loops are more appropriate when you need to control the loop according to conditions or wait for user input, but you need to pay attention to avoid infinite loops. 3) In terms of performance, the for loop is slightly faster, but the difference is usually not large. Choosing the right loop type can improve the efficiency and readability of your code.

In Python, lists can be merged through five methods: 1) Use operators, which are simple and intuitive, suitable for small lists; 2) Use extend() method to directly modify the original list, suitable for lists that need to be updated frequently; 3) Use list analytical formulas, concise and operational on elements; 4) Use itertools.chain() function to efficient memory and suitable for large data sets; 5) Use * operators and zip() function to be suitable for scenes where elements need to be paired. Each method has its specific uses and advantages and disadvantages, and the project requirements and performance should be taken into account when choosing.

Forloopsareusedwhenthenumberofiterationsisknown,whilewhileloopsareuseduntilaconditionismet.1)Forloopsareidealforsequenceslikelists,usingsyntaxlike'forfruitinfruits:print(fruit)'.2)Whileloopsaresuitableforunknowniterationcounts,e.g.,'whilecountdown>

ToconcatenatealistoflistsinPython,useextend,listcomprehensions,itertools.chain,orrecursivefunctions.1)Extendmethodisstraightforwardbutverbose.2)Listcomprehensionsareconciseandefficientforlargerdatasets.3)Itertools.chainismemory-efficientforlargedatas

TomergelistsinPython,youcanusethe operator,extendmethod,listcomprehension,oritertools.chain,eachwithspecificadvantages:1)The operatorissimplebutlessefficientforlargelists;2)extendismemory-efficientbutmodifiestheoriginallist;3)listcomprehensionoffersf

In Python 3, two lists can be connected through a variety of methods: 1) Use operator, which is suitable for small lists, but is inefficient for large lists; 2) Use extend method, which is suitable for large lists, with high memory efficiency, but will modify the original list; 3) Use * operator, which is suitable for merging multiple lists, without modifying the original list; 4) Use itertools.chain, which is suitable for large data sets, with high memory efficiency.

Using the join() method is the most efficient way to connect strings from lists in Python. 1) Use the join() method to be efficient and easy to read. 2) The cycle uses operators inefficiently for large lists. 3) The combination of list comprehension and join() is suitable for scenarios that require conversion. 4) The reduce() method is suitable for other types of reductions, but is inefficient for string concatenation. The complete sentence ends.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 English version
Recommended: Win version, supports code prompts!

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Dreamweaver CS6
Visual web development tools
