c++多態--2(計算器,純虛函數和抽象類)

為什么要用多態

  1. 早期方法不利于擴展
  2. 開閉原則 開閉原則 對擴展開放 對修改關閉
  3. 利用多態實現—利于后期擴展,結構性非常好,可讀性高,效率稍微低,發生多態內部結構復雜

多態成立的條件

  1. 又繼承

  2. 子類重寫父類虛函數的函數:

    a)返回值,函數名字,函數參數,必須和父類完全一致(析構函數除外)
    b)子類中virtual關鍵字可寫可不寫,建議寫

  3. 類型兼容 父類指針,父類引用,指向子類對象

抽象基類和純虛函數

  1. 在設計時,常常希望基類僅僅作為其派生類的一個接口,這就是說,僅想對基類進行向上類型轉換,使用它的接口,
    而不希望用戶實際的創建一個基類的對象,同時創建一個純虛函數允許接口中放置成員原函數,而不是要提供一段可能對這個函數毫無意義的代碼。

  2. 做到這點,可以在基類中加入至少一個純虛函數(pure virtual function),使得基類稱為抽象類(abstract class)

  3. 純虛函數使用關鍵字virtual,并在其后面加上=0,如果試圖去實例化一個抽象類,編譯器則會阻止這種操作。

  4. 當繼承一個抽象類的時候,必須實現所有的純虛函數,否則由抽象類派生的類也是一個抽象類

  5. Virtual void fun()=0;告訴編譯器在vtable中為函數保留一個位置,但在這個特定位置不放地址

建立公共接口目的是為了將子類公共的操作抽象出來,可以通過一個公共接口來操縱一組類,且這個公共接口不需要事先(或者不需要完全實現)。可以創建一個公共類

#include<iostream>using namespace std;
/*
class Calculator
{
public:void setv1(int v){this->val1 = v;}void setv2(int v){this->val2 = v;}int getResult(string oper){if (oper == "+"){return val1 + val2;}else if (oper == "-"){return val1 - val2;}}private:int val1;int val2;
};
void test01()
{Calculator cal;cal.setv1(10);cal.setv2(10);cout << cal.getResult("+") << endl;cout << cal.getResult("-") << endl;
}
*///真正的開發中,有個開發原則,開閉原則
//對擴展開放 對修改關閉//利用多態實現計算器
class abstractCalculator
{
public:void setv1(int v){this->val1 = v;}void setv2(int v){this->val2 = v;}//virtual int getResult(){return  0;} 虛函數//純虛函數//如果父類中有了純虛函數  子類繼承了父類,必須要實現純虛函數//如果父類中 有了純虛函數,這個父類,就無法實例化對象了//這個類中有了純虛函數,通常又稱為 抽象類virtual int getResult() = 0;public:int val1;int val2;
};
//如果父類中有了純虛函數  子類繼承了父類,必須要實現純虛函數
class A :public abstractCalculator
{
public:virtual int getResult(){//return 0;}};//加法計算器 
class PlusCaculator :public abstractCalculator
{
public:virtual int getResult(){return val1 + val2;}
};
//減法計算器
class SubCalculator : public abstractCalculator
{
public:virtual int getResult(){return val1 - val2;}
};//乘法計算器
class ChengCalculator : public abstractCalculator
{
public:virtual int getResult(){return val1*val2;}
};void test01()
{abstractCalculator *abc = new PlusCaculator;//加法計算器abc = new PlusCaculator;abc->setv1(10);abc->setv2(20);cout << abc->getResult() << endl;delete abc;abc = new SubCalculator;abc->setv1(10);abc->setv2(20);cout << abc->getResult() << endl;delete abc;abc = new ChengCalculator;abc->setv1(10);abc->setv2(20);cout << abc->getResult() << endl;//如果父類有了純虛函數,不能實例化對象了/*abstractCalculator aaa;abstractCalculator *abc = new abstractCalculator;*/
}int main()
{test01();system("pause");return 0;
}
  1. 純虛函數寫法 virtual void func()=0;
  2. 抽象類型
  3. 抽象類 不可實例化對象
  4. 如果類 繼承了抽象類,必須重寫抽象類中的純虛函數

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/383303.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/383303.shtml
英文地址,請注明出處:http://en.pswp.cn/news/383303.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

使用Automake和Autoconf生成Makefile

automake 所產生的 Makefile 除了可以做到程序的自動編譯和鏈接 外&#xff0c;還可以用來生成各種文檔&#xff08;如manual page、info文件&#xff09;&#xff0c;可以將源代碼文件包裝起來以供發布。所以程序源代碼所存放的目錄 結構最好符合GNU的標準慣例。下面以hello.…

c++中多態---3(虛析構和純虛析構,向上類型轉化和向下類型轉化)

虛析構和純虛析構 虛析構virtual ~類名(){}類內聲明&#xff0c;類內實現解決問題&#xff1a;通過父類指針指向子類對象釋放時候不干凈的問題 純虛析構 寫法 virtual ~類名(){}0; 類內聲明 類外實現 如果出現了純虛析構函數&#xff0c;這個類也算是抽象類&#xff0c;不可…

嵌入式開發硬件知識札記

三態邏輯 1. 概念 三態指其輸出既可以是一般二值邏輯電路&#xff0c;即正常的高電平&#xff08;邏輯1&#xff09;或低電平&#xff08;邏輯0&#xff09;&#xff0c;又可以保持特有的高阻抗狀態。高阻態相當于隔斷狀態&#xff08;電阻很大&#xff0c;相當于開路&#xff…

《凡人修仙傳》中打斗場景(c++多態實現)

我們 要實現打斗場景&#xff0c;第一&#xff0c;我們需要有打斗的雙方&#xff0c;一個是英雄&#xff0c;一個是怪物&#xff0c;他們都有自己的屬性&#xff0c;比如攻擊&#xff0c;防御&#xff0c;血量。其次我們的英雄還會有武器。武器上有一些加成屬性&#xff0c;可以…

使用mp4v2將aac音頻h264視頻數據封裝成mp4開發心得

這陣子在搗鼓一個將游戲視頻打包成本地可播放文件的模塊。開始使用avi作為容器&#xff0c;弄了半天無奈avi對aac的支持實在有限&#xff0c;在播放時音視頻時無法完美同步。 關于這點avi文檔中有提到&#xff1a; For AAC, one RAW AAC frame usually spans over 1024 samples…

c++模板---1(模板概念,利用模板實現數組排序,函數模板調用規則)

什么叫泛型編程&#xff1f;1. 參數類型化。 2. 模板 模板概念 c提供了函數模板&#xff0c;所謂函數模板&#xff0c;實際上是建立一個通用函數&#xff0c;其函數類型和形參類型不具體制定&#xff0c;用一個虛擬的類型來代表。這個通用函數就成為函數模板。凡是函數體相同…

c++模板--2(模板機制,模板的局限性,類模板,類模板做函數的參數)

函數模板機制結論 編譯器并不是把函數模板處理成能狗處理任何類型的函數函數模板通過具體類型產生不同的函數編譯器會對函數模板進行兩次編譯&#xff0c;在聲明的地方對模板代碼的本身進行編譯&#xff0c;在調用的地方對參數替換后代碼進行編譯在編譯器編譯階段&#xff0c;…

arm-linux 交叉編譯 mp4v2

2014-09-23 14:44 1901人閱讀 評論(0) 收藏 舉報 版權聲明&#xff1a;本文為博主原創文章&#xff0c;未經博主允許不得轉載。 1、下載mp4v2的源代碼&#xff08;http://code.google.com/p/mp4v2/downloads/list&#xff09;mp4v2-2.0.0.tar.bz2 2. 進入相應目錄 ./configu…

c++模板---3(類模板碰到繼承問題,類模板類外實現,類模板與友元函數)

類模板碰到繼承問題 基類如果是模板類&#xff0c;必須讓子類告訴編譯器 基類中的T到底是什么類型 如果不告訴&#xff0c;那么無法分配內存&#xff0c;編譯不過 利用參數列表class Child :public Base<int> #include<iostream>using namespace std;template&l…

Linux USB札記

嵌入式linux內核添加USB模塊&#xff08;U盤&#xff09;支持 使用menuconfig工具進行配置 1、Device Drivers->SCSI device support->SCSI disk support此選項必須勾選 2、Device Drivers->USB support->Support for Host-side USB 此選項選中后會出現子菜單&…

c++實現任意類型數組類的封裝

MyArray.hpp #pragma once #include<iostream> #include<string> using namespace std; template<class T>class MyArray { public://構造explicit MyArray(int capacity) //防止隱式類型轉換&#xff0c;防止MyArray arr 10{this->m_Capacity capacity…

Linux內核配置選項 (經典學習)

轉載地址http://book.csdn.net/bookfiles/972/10097230254.shtml 2.5 Linux內核配置選項 下面以最新的Linux 2.6.20內核為例&#xff0c;介紹比較常用的一些Linux內核配置選項&#xff0c;其他選項讀者可以參考系統提供的幫助信息。 需要說明的是&#xff0c;在內核配置中&am…

深入理解linux系統下proc文件系統內容

另外&#xff0c;可以參考這個http://www.centos.org/docs/5/html/5.1/Deployment_Guide/ch-proc.html 內容摘要&#xff1a;Linux系統上的/proc目錄是一種文件系統&#xff0c;即proc文件系統。 Linux系統上的/proc目錄是一種文件系統&#xff0c;即proc文件系統。與其它常見…

c++中的異常--1(基本概念, c語言中處理異常,c++中處理異常,異常的基本使用,棧解旋)

異常基本概念 異常處理就是處理程序中的錯誤&#xff0c;所謂錯誤是指在程序運行的過程中發生的一些異常事件&#xff08;如&#xff1a;除0退出&#xff0c;數組下標越界&#xff0c;所要讀取的文件不存在&#xff0c;空指針&#xff0c;內存不足等等&#xff09; c語言中處…

RGB、YUV和YCbCr

之前對RGB、YUV和YCbCr一直沒有清晰的理解和認識&#xff0c;今天打算做一個小結&#xff0c;結合網上的文章談談自己的看法&#xff0c;也希望有機會看到這篇文章的人能指點一二&#xff0c;相互交流&#xff0c;共同進步。 首先要說明&#xff0c;上述的RGB、YUV和YCbCr都是人…

c++中的異常---2(異常接口聲明,異常變量的生命周期,異常的多態使用)

異常接口聲明 為了加強程序的可讀性&#xff0c;可以在函數聲明中列出可能拋出異常的所有類型&#xff0c;例如&#xff1a;void func() throw(A,B,C);這個函數func能夠且只能拋出類型A,B,C及其子類的異常如果在函數聲明中沒有包含異常接口聲明&#xff0c;則此函數可以拋任何…

c++中的異常---3(系統標準異常庫,編寫自己異常類)

系統標準異常庫 #incldue out_of_range 等… #include<iostream>#include<string>using namespace std;//系統提供標準異常#include<stdexcept>class Person{public:Person(string name, int age){this->m_Name name;//年齡做檢測if (age<0 || age&g…

H.264中IDR幀和I幀區別

IDR&#xff08;Instantaneous Decoding Refresh&#xff09;--即時解碼刷新。I和IDR幀都是使用幀內預測的。它們都是同一個東西而已,在編碼和解碼中為了方便&#xff0c;要首個I幀和其他I幀區別開&#xff0c;所以才把第一個首個I幀叫IDR&#xff0c;這樣就方便控制編碼和解碼…

c++中的IO流(流的概念和流類庫的結構,標準的輸入輸出流)

流的概念和流類庫的結構 程序的輸入指的是從輸入文件將數據傳送給程序&#xff0c;程序的輸出指的是從程序將數據傳送給輸出文件 c輸入輸出包含以下三個方面的內容 對系統指定的標準設備的輸入輸出。即從鍵盤輸入數據&#xff0c;輸出到顯示器屏幕&#xff0c;這種輸入輸出稱…

MTD應用學習札記

今天做升級方案用到了mtd-utils中的flash_eraseall和flash_cp兩個工具&#xff0c;在進行方案驗證的時候&#xff0c;遭遇到各種不解和疑惑&#xff0c;因對MTD的原理不熟悉&#xff0c;所以只能多次嘗試&#xff0c;雖然最后把方案搞定了&#xff0c;不過覺得MTD中的mtd和mtdb…