Post

模板方法

Template Method

在软件构建的过程中,整体的步骤流程是确定的A->B->C,假设其中A和B的流程完全明确,但是B的整体流程是需要自己实现的。

定义一个操作中的算法的骨架 (稳定),而将一些步骤延迟(变化)到子类中。 Template Method使得子类可以不改变(复用)一个算法的结构即可重定义(overrided写)该算法的某些特定步骤。

一个简单的例子就是:

针对库的开发, 步骤1,3,5固定,步骤2,4是变化的

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
//程序库开发人员
class Library{
public:
	//稳定 template method
    void Run(){
        
        Step1();

        if (Step2()) { //支持变化 ==> 虚函数的多态调用
            Step3(); 
        }

        for (int i = 0; i < 4; i++){
            Step4(); //支持变化 ==> 虚函数的多态调用
        }

        Step5();

    }
	virtual ~Library(){ }

protected:
	
	void Step1() { //稳定
        //.....
    }
	void Step3() {//稳定
        //.....
    }
	void Step5() { //稳定
		//.....
	}

	virtual bool Step2() = 0;//变化
    virtual void Step4() =0; //变化
};

因此,可以在实现上继承这个lib

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
//应用程序开发人员
class Application : public Library {
protected:
	virtual bool Step2(){
		//... 子类重写实现
    }

    virtual void Step4() {
		//... 子类重写实现
    }
};

int main()
	{
	    Library* pLib=new Application();
	    lib->Run();

		delete pLib;
	}
}

c++继承体系中的public, private, protected

继承方式父类的public成员父类的protected成员父类的private成员关系描述
public依然为public依然为protected不可见 
protected变为protected成员变为protected成员不可见 
private变为private成员变成private成员不可见 

protected存在的理由就是继承类中访问基类的protected成员。

引入保护成员的理由是:基类的成员本来就是派生类的成员,因此对于那些出于隐藏的目的不宜设为公有,但又确实需要在派生类的成员函数中经常访问的基类成员,将它们设置为保护成员,既能起到隐藏的目的,又避免了派生类成员函数要访问它们时只能间接访问所带来的麻烦。

This post is licensed under CC BY 4.0 by the author.

Trending Tags