Java對Override方法調用采取的是運行時綁定,也就是按照對象的實際類型來決定調用的方法,而不是按照對象的聲明類型來決定調用方法,是一種向上轉型。而Overload方法則想法是在編譯時進行靜態綁定的,按照聲明類型決定調用的方法。這點C++也是一樣的
class father
{
void f()
{
System.out.println("father::f");
}
}
public class Son extends father{
void f()
{
System.out.println("son::f");
}
public static void main(String[] argv)
{
father f = new Son();
f.f();
}
}
運行結果:son::f
C++支持兩種多態性:a編譯時多態性:通過重載函數實現,b運行時多態性:通過虛函數實現。
最常見的用法就是聲明基類的指針,利用該指針指向任意一個子類對象,調用相應的虛函數,可以根據指向的子類的不同而實現不同的方法。如果沒有使用虛函數的話,即沒有利用C++多態性,則利用基類指針調用相應的函數的時候,將總被限制在基類函數本身,而無法調用到子類中被重寫過的函數。
#include <iostream>
using namespace std;
class B{
public:
virtual void f() const {cout<<"B::f";}
void k() {cout<<"B::k";}
};
class D : public B
{
public:
void f() const {cout<<"D::f";}//overrides
void k() const{cout<<"D::k";}
};
main(void)
{
B *ptr,b;
D d;
d.k();
ptr =new D;
ptr->f();
ptr->k();
b.f();
b.k();
}
運行結果:D::kD::fB::kB::fB::k
《C++ 設計新思維》 下載見 http://www.linuxidc.com/Linux/2014-07/104850.htm
C++ Primer Plus 第6版 中文版 清晰有書簽PDF+源代碼 http://www.linuxidc.com/Linux/2014-05/101227.htm
讀C++ Primer 之構造函數陷阱 http://www.linuxidc.com/Linux/2011-08/40176.htm
讀C++ Primer 之智能指針 http://www.linuxidc.com/Linux/2011-08/40177.htm
讀C++ Primer 之句柄類 http://www.linuxidc.com/Linux/2011-08/40175.htm
將C語言梳理一下,分布在以下10個章節中: