當類別有成員函數宣告為 virtual 的時候,此成員函數可作動態綁定 (dynamic binding) ,這是說不需區分該成員函數定義在衍生類別或基礎類別裡。
這樣的機制被稱為虛擬機制 (virtual mechanism) ,必須在參考或指標才可使用。
舉例如下
001 | #include <iostream> |
002 | |
003 | class Demo { |
004 | public: |
005 | virtual int do_something() { |
006 | return 1; |
007 | } |
008 | }; |
009 | |
010 | class Demo2: public Demo { |
011 | public: |
012 | virtual int do_something() { |
013 | return 2; |
014 | } |
015 | }; |
016 | |
017 | int main(void) { |
018 | Demo* d_ptr; |
019 | Demo2 d2; |
020 | d_ptr = &d2; |
021 | |
022 | std::cout << d_ptr->do_something() |
023 | << std::endl; |
024 | |
025 | return 0; |
026 | } |
027 | |
028 | /* Kaiching Chang |
029 | u0919.cpp |
030 | 2014-02 */ |
Demo 與 Demo2 都有 virtual 的 do_something() 函數成員,這裡用指向 Demo 的指標呼叫 Demo2 的 do_something()
018 | Demo* d_ptr; |
019 | Demo2 d2; |
020 | d_ptr = &d2; |
021 | |
022 | std::cout << d_ptr->do_something() |
023 | << std::endl; |
編譯執行,結果如下
g$ g++ u0919.cpp |
$ ./a.out |
2 |
$ |
continue ...
沒有留言:
張貼留言