您好,登錄后才能下訂單哦!
這篇文章主要介紹C語言模式中如何實現C++繼承和多態,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
這個問題主要考察的是C和C++的區別,以及C++中繼承和多態的概念。
C和C++的區別
C語言是面向過程的語言,而C++是面向對象的過程。
什么是面向對象和面向過程?
面向過程就是分析解決問題的步驟,然后用函數把這些步驟一步一步的進行實現,在使用的時候進行一一調用就行了,注重的是對于過程的分析。面向對象則是把構成問題的事進行分成各個對象,建立對象的目的也不僅僅是完成這一個個步驟,而是描述各個問題在解決的過程中所發生的行為。
面向對象和面向過程的區別?
面向過程的設計方法采用函數來描述數據的操作,但將函數與操作的數據進行分離開來。
面向對象的設計方法是將對象和數據進行封裝起來成為一個整體。
面向過程以設計步驟為過程,后期難以維護。
面向對象設計以數據為中心,數據相對與功能來說具有較強的穩定性更加易于維護。
面向對象的三大特征
封裝:
對于封裝來說就是數據與具體操作實現的代碼都放在某個對象的內部,使這些代碼的具體細節不被外界發現,只留下一些接口供外部來使用,而不能一任何的形式來對象內部的實現。使用封裝能夠隱藏具體的實現的細節,使代碼更加易于維護并且保證了系統的安全性。
繼承:
繼承機制是面向對象程序設計使代碼進行復用的最重要的手段,他允許程序員在保證類原有類特性的基礎上進行擴展來增加功能。這樣新產生的類就被稱為派生類,繼承就可以表現面向對象機制的的層次結構。
多態:
多態簡單點說就是“一個接口,多種實現”,就是同一種事物表現出的多種形態。多態在面向對象語言中是指:接口多種的不同實現方式。也就是復用相同接口,實現不同操作。
C++多態支持兩種多態性,編譯時多態和運行時多態。編譯時多態是通過重載函數來實現的,運行時多態是通過虛函數來實現的。靜態多態:編譯器在編譯期間完成,編譯器根據函數實參的類型(可能會隱式類型轉換),可推斷出要調用哪個函數,如果有對應的函數就調用相應的函數,否則就報一個編譯錯誤。動態多態:在函數執行期間(非編譯期)判斷所引用對象的實際類型,根據實際類型的調用相應的方法。使用virtual關鍵字修飾類的成員函數,指明該函數為虛函數,派生類需要重新實現,編譯器將實現動態綁定。
動態多態實現的條件:
1>、使用場景:父類的指針或者引用指向父類或者子類的對象(由賦值兼容規則決定);
2>、實現多態的兩個條件:虛函數的重寫;父類的指針或者引用調用重寫的虛函數。
3>、若父類中的成員函數加上virtual關鍵字,則子類中重寫的該函數默認virtual,可以不指定,但是一般加上;
重寫:子類重寫父類的虛函數,要求函數名稱,函數參數,返回值完全一樣(協變除外);
總的來說:封裝可以隱藏實現細節包括包含私有成員,使得代碼模塊增加安全指數;繼承可以擴展已存在的模塊,為了增加代碼的復用性;多態則是為了保證類在繼承和派生的時候,類的實例被正確調用,實現了接口的重用
C模擬實現多態
C++中的多態
我們知道的是在C++中會維護一張虛函數表,根據賦值兼容規則,我們知道父類的指針或者引用是可以指向子類對象的。如果一個父類的指針或者引用調用父類的虛函數則該父類的指針會在自己的虛函數表中查找自己的函數地址,如果該父類對象的指針或者引用指向的是子類的對象,而且該子類已經重寫了父類的虛函數,則該指針會調用子類的已經重寫的虛函數。
//c++中的多態 class A { public: virtual void fun()//虛函數實現 { cout << "Base A::fun() " << endl; } }; class B:public A { public: virtual void fun()//虛函數實現,子類中virtual關鍵字可以沒有 { cout << "Derived B::fun() " << endl; } }; void Test1() { A a;//基類對象 B b;//派生類對象 A* pa = &a;//父類指針指向父類對象 pa->fun();//調用父類的函數 pa = &b; //父類指針指向子類對象,多態實現 pa->fun();//調用派生類同名函數 }
c語言實現多態
我們知道在C語言中是沒有class類這個概念的,但是有struct結構體,我們可以考慮使用struct來模擬;但是在C語言的結構體內部是沒有成員函數的,如果實現這個父結構體和子結構體共有的函數呢?我們可以考慮使用函數指針來模擬。但是這樣處理存在一個缺陷就是:父子各自的函數指針之間指向的不是類似C++中維護的虛函數表而是一塊物理內存,如果模擬的函數過多的話就會不容易維護了。
//C實現動態,用到函數指針 typedef void(*FUN)();//重定義一個函數指針類型 //父類 struct Base { FUN _f; }; //子類 struct Derived { Base _b;//在子類中定義一個基類的對象即可實現對父類的繼承 }; void FunB() { printf("%s\n", "Base::fun()"); } void FunD() { printf("%s\n", "Derived::fun()"); } void Test2() { Base b;//父類對象 Derived d;//子類對象 b._f = FunB;//父類對象調用父類同名函數 d._b._f = FunD;//子類調用子類的同名函數 Base *pb = &b;//父類指針指向父類對象 pb->_f(); pb = (Base *)&d;//讓父類指針指向子類的對象,由于類型不匹配所以要進行強轉 pb->_f(); }
以上是“C語言模式中如何實現C++繼承和多態”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。