In the software construction process, there is often a stable overall operational structure for a task, but the various sub-steps have many requirements for change or cannot be implemented simultaneously with the overall structure of the task due to inherent reasons (such as the relationship between the framework and the application).

 

How to flexibly respond to the changes of each sub-step or the late implementation requirements on the premise of determining the stable operation structure?

Template method

 

Schema definition:

Define the skeleton (stable) of an algorithm in an operation, while deferring (varying) some steps to subclasses. Template Method allows subclasses to redefine (override override) certain steps of the Method without changing (reusing) the mechanism of an algorithm

 

 

Structured software design process

 

Object-oriented software design process

 

Summary of main points:

Template Method pattern is a very basic design pattern, which has a lot of applications in object-oriented systems. It provides flexible extension points for many application frameworks with the simplest mechanism (polymorphisms of virtual functions) and is the basic implementation structure for code reuse

 

In addition to being flexible to changes in substeps, the “don’t call me, let me call you” reverse control structure is a typical application of the Template Method

 

On the implementation side, the virtual methods called by the Template Method can be implemented or have no implementation at all (abstract methods, pure virtual methods), but it is generally recommended that they be protected