定義乙個操作中的演算法骨架,而將一些步驟延遲到子類中。用一句聽得懂的話說,就是把乙個演算法中不變的部分搬移到超類——父類中,把變的部分留給子類,通過介面重寫的方式完成各自變化的部分。好處是,減少了**的耦合,提高了復用。
簡單**如下:
class father_class
; //可變部分
virtual void method1() = 0;
virtual void method2() = 0;
};class sub1:public father_class
; virtual void method2();
};class sub2 :public father_class
; virtual void method2();
};int main()
第二十三模板 12約束模板
第二十三模板 12約束模板 結束模板的大意,即是對模板的資料和方法有要求 templatet max t a,t b 假如比較的型別是兩個指向字串的指標,則比較運算子 比較的是兩個位址而不是數值 char max char a,char b 該函式具體化了max函式的兩個引數和功能,該函式的兩個引數...
第二十三模板 18 5數值演算法
第二十三模板 18.5數值演算法 stl的數值演算法可以對乙個序列的元素進行四種計算,接下來將逐步講述這四種計算方法 1 accumulate first,last,init include include include include using namespace std void show ...
第二十三模板 18 4演算法類
第二十三模板 18.4演算法類 stl 標準模板庫 通用演算法共分四大類 不變序列演算法 不對其所作用的容器進行修改 改變序列演算法 對其所作用的容器進行修改 排序演算法 對容器中的元素採用多種方式進行排序 數值演算法 對容器中的元素進行數值計算 這些演算法全部在標準命名空間std中的中定義 1 函...