日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

C/C++面试题精选

發(fā)布時間:2025/3/21 c/c++ 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C/C++面试题精选 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

轉(zhuǎn)載來自:http://blog.csdn.net/cadcisdhht/article/category/785138

總結(jié)

  • ?static的作用是表示該函數(shù)只作用在類型的靜態(tài)變量上,與類的實例沒有關系;而const的作用是確保函數(shù)不能修改類的實例的狀態(tài),與類型的靜態(tài)變量沒有關系。因此不能同時用它們。
  • ?空類實例不包含信息,本來求sizeof應該是0。但當我們聲明該類型的實例的時候,它必須在內(nèi)存中占有一定的空間,否則無法使用這些實例。至于占用多少內(nèi)存,由編譯器決定。Visual Studio 2008中每個空類型的實例占用一個byte的空間。由于構(gòu)造函數(shù)和析構(gòu)函數(shù)的調(diào)用與類型的實例無關(調(diào)用它們只需要知道函數(shù)地址即可),在它的實例中不需要增加任何信息。C++的編譯器一旦發(fā)現(xiàn)一個類型中有虛擬函數(shù),就會為該類型生成虛函數(shù)表,并在該類型的每一個實例中添加一個指向虛函數(shù)表的指針。在32位的機器上,一個指針占4個字節(jié)的空間。
  • ?每個非靜態(tài)類成員函數(shù)都隱藏一個指向自己實例的this指針。
  • ?調(diào)用虛函數(shù)需要從一個實例中指向虛函數(shù)表的指針以得到函數(shù)的地址,因此調(diào)用虛函數(shù)需要一個實例。調(diào)用靜態(tài)成員函數(shù)不要實例。
  • ?&(pPoint->z)的語意是求pPoint中變量z的地址(pPoint的地址0z的偏移量8),并不需要訪問pPoint指向的內(nèi)存。
  • ?如果沒有標明函數(shù)或者變量是的訪問權(quán)限級別,在struct中,是public的;而在class中,是private的。
  • ?C++中,成員變量的初始化順序與變量在類型中的申明順序相同,而與它們在構(gòu)造函數(shù)的初始化列表中的順序無關。
  • ?如果允許復制構(gòu)造函數(shù)傳值,那么會形成永無休止的遞歸并造成棧溢出,編譯錯誤。因此C++的標準不允許復制構(gòu)造函數(shù)傳值參數(shù),而必須是傳引用或者常量引用。
  • ?sizeof(數(shù)組)是求數(shù)組的大小。?sizeof(指針)是求指針的大小,32位機器上,任意指針都占4個字節(jié)的空間當數(shù)組作為函數(shù)的參數(shù)進行傳遞時,數(shù)組就自動退化為同類型的指針
  • ?缺省參數(shù)的值是在編譯的時候,但確定引用、指針的虛函數(shù)調(diào)用哪個類型的函數(shù)是在運行的時候。
  • ?char?p[] =?"Hello World";p是一個數(shù)組,會開辟一塊內(nèi)存,并拷貝"Hello World"初始化該數(shù)組。

  • 題目

    題目(一):C++中我們可以用static修飾一個類的成員函數(shù),也可以用const修飾類的成員函數(shù)(寫在函數(shù)的最后表示不能修改成員變量,不是指寫在前面表示返回值為常量)。請問:能不能同時用staticconst修飾類的成員函數(shù)?

    分析:答案是不可以。C++編譯器在實現(xiàn)const的成員函數(shù)的時候為了確保該函數(shù)不能修改類的實例的狀態(tài),會在函數(shù)中添加一個隱式的參數(shù)const this*。但當一個成員為static的時候,該函數(shù)是沒有this指針的。也就是說此時static的用法和static是沖突的。

    我們也可以這樣理解:兩者的語意是矛盾的。static的作用是表示該函數(shù)只作用在類型的靜態(tài)變量上,與類的實例沒有關系;而const的作用是確保函數(shù)不能修改類的實例的狀態(tài),與類型的靜態(tài)變量沒有關系。因此不能同時用它們。

    題目(二):運行下面C++代碼,輸出是什么?

    [cpp] view plain copy
  • class?A??
  • {??
  • };??
  • ???
  • class?B??
  • {??
  • public:??
  • ????????B()?{}??
  • ????????~B()?{}??
  • };??
  • ???
  • class?C??
  • {??
  • public:??
  • ????????C()?{}??
  • ????????virtual?~C()?{}??
  • };??
  • ???
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ????????printf("%d,?%d,?%d/n",?sizeof(A),?sizeof(B),?sizeof(C));??
  • ????????return?0;??
  • }??
  • 分析:答案是1, 1, 4class A是一個空類型,它的實例不包含任何信息,本來求sizeof應該是0。但當我們聲明該類型的實例的時候,它必須在內(nèi)存中占有一定的空間,否則無法使用這些實例。至于占用多少內(nèi)存,由編譯器決定。Visual Studio 2008中每個空類型的實例占用一個byte的空間。

    class Bclass A的基礎上添加了構(gòu)造函數(shù)和析構(gòu)函數(shù)。由于構(gòu)造函數(shù)和析構(gòu)函數(shù)的調(diào)用與類型的實例無關(調(diào)用它們只需要知道函數(shù)地址即可),在它的實例中不需要增加任何信息。所以sizeof(B)sizeof(A)一樣,在Visual Studio 2008中都是1

    class Cclass B的基礎上把析構(gòu)函數(shù)標注為虛擬函數(shù)。C++的編譯器一旦發(fā)現(xiàn)一個類型中有虛擬函數(shù),就會為該類型生成虛函數(shù)表,并在該類型的每一個實例中添加一個指向虛函數(shù)表的指針。在32位的機器上,一個指針占4個字節(jié)的空間,因此sizeof(C)4

    題目(三):運行下面的C++代碼,得到的結(jié)果是什么

    分析:答案是Print1調(diào)用正常,打印出hello world,但運行至Print2時,程序崩潰。調(diào)用Print1時,并不需要pA的地址,因為Print1的函數(shù)地址是固定的。編譯器會給Print1傳入一個this指針,該指針為NULL,但在Print1中該this指針并沒有用到。只要程序運行時沒有訪問不該訪問的內(nèi)存就不會出錯,因此運行正常。在運行print2時,需要this指針才能得到m_value的值。由于此時this指針為NULL,因此程序崩潰了。

    題目(四):運行下面的C++代碼,得到的結(jié)果是什么

    [cpp] view plain copy
  • class?A??
  • {??
  • private:??
  • ????????int?m_value;??
  • ???
  • public:??
  • ????????A(int?value)??
  • ????????{??
  • ????????????????m_value?=?value;??
  • ????????}??
  • ????????void?Print1()??
  • ????????{??
  • ????????????????printf("hello?world");??
  • ????????}??
  • ????????virtual?void?Print2()??
  • ????????{??
  • ????????????????printf("hello?world");??
  • ????????}??
  • };??
  • ???
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ????????A*?pA?=?NULL;??
  • ????????pA->Print1();??
  • ????????pA->Print2();??
  • ???
  • ????????return?0;??
  • }??
  • 分析:答案是Print1調(diào)用正常,打印出hello world,但運行至Print2時,程序崩潰。Print1的調(diào)用情況和上面的題目一樣,不在贅述。由于Print2是虛函數(shù)。C++調(diào)用虛函數(shù)的時候,要根據(jù)實例(即this指針指向的實例)中虛函數(shù)表指針得到虛函數(shù)表,再從虛函數(shù)表中找到函數(shù)的地址。由于這一步需要訪問實例的地址(即this指針),而此時this指針為空指針,因此導致內(nèi)存訪問出錯。

    題目(五):C++中靜態(tài)成員函數(shù)能不能同時也是虛函數(shù)

    [cpp] view plain copy
  • class?A??
  • {??
  • private:??
  • ????????int?m_value;??
  • ???
  • public:??
  • ????????A(int?value)??
  • ????????{??
  • ????????????????m_value?=?value;??
  • ????????}??
  • ????????void?Print1()??
  • ????????{??
  • ????????????????printf("hello?world");??
  • ????????}??
  • ????????void?Print2()??
  • ????????{??
  • ????????????????printf("%d",?m_value);??
  • ????????}??
  • };??
  • ???
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ????????A*?pA?=?NULL;??
  • ????????pA->Print1();??
  • ????????pA->Print2();??
  • ???
  • ????????return?0;??
  • }??
  • 分析:答案是不能。調(diào)用靜態(tài)成員函數(shù)不要實例。但調(diào)用虛函數(shù)需要從一個實例中指向虛函數(shù)表的指針以得到函數(shù)的地址,因此調(diào)用虛函數(shù)需要一個實例。兩者相互矛盾。

    題目(六):運行下列C++代碼,輸出什么?

    [cpp] view plain copy
  • struct?Point3D??
  • {??
  • ????????int?x;??
  • ????????int?y;??
  • ????????int?z;??
  • };??
  • ???
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ????????Point3D*?pPoint?=?NULL;??
  • ????????int?offset?=?(int)(&(pPoint)->z);??
  • ???
  • ????????printf("%d",?offset);??
  • ????????return?0;??
  • }??
  • 答案:輸出8。由于在pPoint->z的前面加上了取地址符號,運行到此時的時候,會在pPoint的指針地址上加z在類型Point3D中的偏移量8。由于pPoint的地址是0,因此最終offset的值是8

    &(pPoint->z)的語意是求pPoint中變量z的地址(pPoint的地址0z的偏移量8),并不需要訪問pPoint指向的內(nèi)存。只要不訪問非法的內(nèi)存,程序就不會出錯。

    題目(七):運行下列C++代碼,輸出什么?

    [cpp] view plain copy
  • class?A??
  • {??
  • public:??
  • ????????A()??
  • ????????{??
  • ????????????????Print();??
  • ????????}??
  • ????????virtual?void?Print()??
  • ????????{??
  • ????????????????printf("A?is?constructed./n");??
  • ????????}??
  • };??
  • ???
  • class?B:?public?A??
  • {??
  • public:??
  • ????????B()??
  • ????????{??
  • ????????????????Print();??
  • ????????}??
  • ???
  • ????????virtual?void?Print()??
  • ????????{??
  • ????????????????printf("B?is?constructed./n");??
  • ????????}??
  • };??
  • ???
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ????????A*?pA?=?new?B();??
  • ????????delete?pA;??
  • ???
  • ????????return?0;??
  • }??
  • 答案:先后打印出兩行:A is constructed. B is constructed.?調(diào)用B的構(gòu)造函數(shù)時,先會調(diào)用B的基類及A的構(gòu)造函數(shù)。然后在A的構(gòu)造函數(shù)里調(diào)用Print。由于此時實例的類型B的部分還沒有構(gòu)造好,本質(zhì)上它只是A的一個實例,他的虛函數(shù)表指針指向的是類型A的虛函數(shù)表。因此此時調(diào)用的PrintA::Print,而不是B::Print。接著調(diào)用類型B的構(gòu)造函數(shù),并調(diào)用Print。此時已經(jīng)開始構(gòu)造B,因此此時調(diào)用的PrintB::Print

    同樣是調(diào)用虛擬函數(shù)Print,我們發(fā)現(xiàn)在類型A的構(gòu)造函數(shù)中,調(diào)用的是A::Print,在B的構(gòu)造函數(shù)中,調(diào)用的是B::Print。因此虛函數(shù)在構(gòu)造函數(shù)中,已經(jīng)失去了虛函數(shù)的動態(tài)綁定特性。

    題目(八):C++中,structclass有什么不同

    答案:C++中,如果沒有標明函數(shù)或者變量是的訪問權(quán)限級別,在struct中,是public的;而在class中,是private的。

    題目(:運行下圖中的C++代碼,輸出是什么

    [cpp] view plain copy
  • #include?<iostream>??
  • ???
  • class?A??
  • {??
  • private:??
  • ????????int?n1;??
  • ????????int?n2;??
  • public:??
  • ????????A():?n2(0),?n1(n2?+?2)??
  • ????????{??
  • ????????}??
  • ???
  • ????????void?Print()??
  • ????????{??
  • ????????????????std::cout?<<?"n1:?"?<<?n1?<<?",?n2:?"?<<?n2?<<?std::endl;??
  • ????????}??
  • };??
  • ???
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ????????A?a;??
  • ????????a.Print();??
  • ???
  • ????????return?0;??
  • }??
  • 答案:輸出n1是一個隨機的數(shù)字,n20。在C++中,成員變量的初始化順序與變量在類型中的申明順序相同,而與它們在構(gòu)造函數(shù)的初始化列表中的順序無關。因此在這道題中,會首先初始化n1,而初始n1的參數(shù)n2還沒有初始化,是一個隨機值,因此n1就是一個隨機值。初始化n2時,根據(jù)參數(shù)0對其初始化,故n2=0

    題目(十)編譯運行下圖中的C++代碼,結(jié)果是什么?(A)編譯錯誤;(B)編譯成功,運行時程序崩潰;(C)編譯運行正常,輸出10。請選擇正確答案并分析原因

    [cpp] view plain copy
  • #include?<iostream>??
  • ???
  • class?A??
  • {??
  • private:??
  • ????????int?value;??
  • ???
  • public:??
  • ????????A(int?n)??
  • ????????{??
  • ????????????????value?=?n;??
  • ????????}??
  • ???
  • ????????A(A?other)??
  • ????????{??
  • ????????????????value?=?other.value;??
  • ????????}??
  • ???
  • ????????void?Print()??
  • ????????{??
  • ????????????????std::cout?<<?value?<<?std::endl;??
  • ????????}??
  • };??
  • ???
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ????????A?a?=?10;??
  • ????????A?b?=?a;??
  • ????????b.Print();??
  • ???
  • ????????return?0;??
  • }??
  • 答案:編譯錯誤。在復制構(gòu)造函數(shù)中傳入的參數(shù)是A的一個實例。由于是傳值,把形參拷貝到實參會調(diào)用復制構(gòu)造函數(shù)。因此如果允許復制構(gòu)造函數(shù)傳值,那么會形成永無休止的遞歸并造成棧溢出。因此C++的標準不允許復制構(gòu)造函數(shù)傳值參數(shù),而必須是傳引用或者常量引用。在Visual StudioGCC中,都將編譯出錯。

    題目(十一)運行下圖中的C++代碼,輸出是什么

    [cpp] view plain copy
  • int?SizeOf(char?pString[])??
  • {??
  • ????????return?sizeof(pString);??
  • }??
  • ???
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ????????char*?pString1?=?"google";??
  • ????????int?size1?=?sizeof(pString1);??
  • ????????int?size2?=?sizeof(*pString1);??
  • ???
  • ????????char?pString2[100]?=?"google";??
  • ????????int?size3?=?sizeof(pString2);??
  • ????????int?size4?=?SizeOf(pString2);??
  • ???
  • ????????printf("%d,?%d,?%d,?%d",?size1,?size2,?size3,?size4);??
  • ???
  • ????????return?0;??
  • }??
  • 答案4, 1, 100, 4pString1是一個指針。在32位機器上,任意指針都占4個字節(jié)的空間。*pString1是字符串pString1的第一個字符。一個字符占一個字節(jié)。pString2是一個數(shù)組,sizeof(pString2)是求數(shù)組的大小。這個數(shù)組包含100個字符,因此大小是100個字節(jié)。而在函數(shù)SizeOf中,雖然傳入的參數(shù)是一個字符數(shù)組,當數(shù)組作為函數(shù)的參數(shù)進行傳遞時,數(shù)組就自動退化為同類型的指針。

    題目(十二:運行下圖中代碼,輸出的結(jié)果是什么?這段代碼有什么問題

    [cpp] view plain copy
  • #include?<iostream>??
  • ???
  • class?A??
  • {??
  • public:??
  • ????????A()??
  • ????????{???????std::cout?<<?"A?is?created."?<<?std::endl;????????}??
  • ???
  • ????????~A()??
  • ????????{???????std::cout?<<?"A?is?deleted."?<<?std::endl;????????}??
  • };??
  • ???
  • class?B?:?public?A??
  • {??
  • public:??
  • ????????B()??
  • ????????{???????std::cout?<<?"B?is?created."?<<?std::endl;????????}??
  • ???
  • ????????~B()??
  • ????????{???????std::cout?<<?"B?is?deleted."?<<?std::endl;????????}??
  • };??
  • ???
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ????????A*?pA?=?new?B();??
  • ????????delete?pA;??
  • ???
  • ????????return?0;??
  • }??
  • 答案:輸出三行,分別是:A is created. B is created. A is deleted。用new創(chuàng)建B時,回調(diào)用B的構(gòu)造函數(shù)。在調(diào)用B的構(gòu)造函數(shù)的時候,會先調(diào)用A的構(gòu)造函數(shù)。因此先輸出A is created. B is created.

    接下來運行delete語句時,會調(diào)用析構(gòu)函數(shù)。由于pA被聲明成類型A的指針,同時基類A的析構(gòu)函數(shù)沒有標上virtual,因此只有A的析構(gòu)函數(shù)被調(diào)用到,而不會調(diào)用B的析構(gòu)函數(shù)。

    由于pA實際上是指向一個B的實例的指針,但在析構(gòu)的時候只調(diào)用了基類A的析構(gòu)函數(shù),卻沒有調(diào)用B的析構(gòu)函數(shù)。這就是一個問題。如果在類型B中創(chuàng)建了一些資源,比如文件句柄、內(nèi)存等,在這種情況下都得不到釋放,從而導致資源泄漏。

    問題(十三):運行如下的C++代碼,輸出是什么?

    [cpp] view plain copy
  • class?A??
  • {??
  • public:??
  • ???virtual?void?Fun(int?number?=?10)??
  • ???{??
  • ???????std::cout?<<?"A::Fun?with?number?"?<<?number;??
  • ???}??
  • };??
  • ???
  • class?B:public?A??
  • {??
  • public:??
  • ???virtual?void?Fun(int?number?=?20)??
  • ???{??
  • ???????std::cout?<<?"B::Fun?with?number?"?<<?number;??
  • ???}??
  • };??
  • ???
  • int?main()??
  • {??
  • ???B?b;??
  • ???A?&a?=?b;??
  • ???a.Fun();??
  • }??
  • 答案:輸出B::Fun with number 10。由于a是一個指向B實例的引用,因此在運行的時候會調(diào)用B::Fun。但缺省參數(shù)是在編譯期決定的。在編譯的時候,編譯器只知道a是一個類型a的引用,具體指向什么類型在編譯期是不能確定的,因此會按照A::Fun的聲明把缺省參數(shù)number設為10。

    ???????????這一題的關鍵在于理解確定缺省參數(shù)的值是在編譯的時候,但確定引用、指針的虛函數(shù)調(diào)用哪個類型的函數(shù)是在運行的時候。

    問題(十四):運行如下的C代碼,輸出是什么?

    [cpp] view plain copy
  • char*?GetString1()??
  • {??
  • ???char?p[]?=?"Hello?World";??
  • ???return?p;??
  • }??
  • ???
  • char*?GetString2()??
  • {??
  • ???char?*p?=?"Hello?World";??
  • ???return?p;??
  • }??
  • ???
  • ???
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ???printf("GetString1?returns:?%s.?/n",?GetString1());??
  • ???printf("GetString2?returns:?%s.?/n",?GetString2());??
  • ???
  • ???return?0;??
  • }??
  • 答案:輸出兩行,第一行GetString1 returns:?后面跟的是一串隨機的內(nèi)容,而第二行GetString2 returns: Hello World.兩個函數(shù)的區(qū)別在于GetString1中是一個數(shù)組,而GetString2中是一個指針。

    當運行到GetString1時,p是一個數(shù)組,會開辟一塊內(nèi)存,并拷貝"Hello World"初始化該數(shù)組。接著返回數(shù)組的首地址并退出該函數(shù)。由于p是GetString1內(nèi)的一個局部變量,當運行到這個函數(shù)外面的時候,這個數(shù)組的內(nèi)存會被釋放掉。因此在_tmain函數(shù)里再去訪問這個數(shù)組的內(nèi)容時,結(jié)果是隨機的。

    當運行到GetString2時,p是一個指針,它指向的是字符串常量區(qū)的一個常量字符串。該常量字符串是一個全局的,并不會因為退出函數(shù)GetString2而被釋放掉。因此在_tmain中仍然根據(jù)GetString2返回的地址得到字符串"Hello World"。

    問題(十五):運行下圖中C代碼,輸出的結(jié)果是什么?

    [cpp] view plain copy
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ???char?str1[]?=?"hello?world";??
  • ???char?str2[]?=?"hello?world";??
  • ???
  • ???char*?str3?=?"hello?world";??
  • ???char*?str4?=?"hello?world";??
  • ???
  • ???if(str1?==?str2)??
  • ???????printf("str1?and?str2?are?same./n");??
  • ???else??
  • ???????printf("str1?and?str2?are?not?same./n");??
  • ???
  • ???if(str3?==?str4)??
  • ???????printf("str3?and?str4?are?same./n");??
  • ???else??
  • ???????printf("str3?and?str4?are?not?same./n");??
  • ???
  • ???return?0;??
  • }??
  • 答案輸出兩行。第一行是str1 and str2 are not same,第二行是str3 and str4 are same。

    str1和str2是兩個字符串數(shù)組。我們會為它們分配兩個長度為12個字節(jié)的空間,并把"hello world"的內(nèi)容分別拷貝到數(shù)組中去。這是兩個初始地址不同的數(shù)組,因此比較str1和str2的值,會不相同。str3和str4是兩個指針,我們無需為它們分配內(nèi)存以存儲字符串的內(nèi)容,而只需要把它們指向"hello world“在內(nèi)存中的地址就可以了。由于"hello world”是常量字符串,它在內(nèi)存中只有一個拷貝,因此str3和str4指向的是同一個地址。因此比較str3和str4的值,會是相同的。

    問題(十六):運行下圖中的C++代碼,打印出的結(jié)果是什么?

    [cpp]?view plaincopy
  • bool?Fun1(char*?str)??
  • {??
  • ????printf("%s\n",str);??
  • ????return?false;??
  • }??
  • ??
  • bool?Fun2(char*?str)??
  • {??
  • ????printf("%s\n",str);??
  • ????return?true;??
  • }??
  • ??
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ????bool?res1,res2;??
  • ????res1?=?(Fun1("a")&&?Fun2("b"))?||?(Fun1("c")?||?Fun2("d"));??
  • ????res2?=?(Fun1("a")&&?Fun2("b"))?&&(Fun1("c")?||?Fun2("d"));??
  • ??
  • ????return?res1||?res2;??
  • }??
  • 答案 :打印出4行,分別是a、c、d、a。

    在C/C++中,與、或運算是從左到右的順序執(zhí)行的。在計算rest1時,先計算Fun1(“a”)&& Func2(“b”)。首先Func1(“a”)打印出內(nèi)容為a的一行。由于Fun1(“a”)返回的是false,無論Func2(“b”)的返回值是true還是false,Fun1(“a”)&& Func2(“b”)的結(jié)果都是false。由于Func2(“b”)的結(jié)果無關重要,因此Func2(“b”)會略去而不做計算。接下來計算Fun1(“c”)|| Func2(“d”),分別打印出內(nèi)容c和d的兩行。

    ??????????????? 在計算rest2時,首先Func1(“a”)打印出內(nèi)容為a的一行。由于Func1(“a”)返回false,和前面一樣的道理,Func2(“b”)會略去不做計算。由于Fun1(“a”)&& Func2(“b”)的結(jié)果是false,不管Fun1(“c”)&& Func2(“d”)的結(jié)果是什么,整個表達式得到的結(jié)果都是false,因此Fun1(“c”) || Func2(“d”)都將被忽略。

    問題(十七):運行下面的C++代碼,打印的結(jié)果是什么?

    [cpp]?view plaincopy
  • class?Base??
  • {??
  • public:??
  • ????voidprint()?{?doPrint();}??
  • ??
  • private:??
  • ????virtual?void?doPrint()?{cout?<<?"Base::doPrint"?<<?endl;}??
  • };??
  • ??
  • class?Derived?:?public?Base??
  • {??
  • private:??
  • ????virtual?void?doPrint()?{cout?<<?"Derived::doPrint"?<<?endl;}??
  • };??
  • ??
  • int?_tmain(int?argc,?_TCHAR*?argv[])??
  • {??
  • ????Base?b;??
  • ????b.print();??
  • ??
  • ????Derived?d;??
  • ????d.print();??
  • ??
  • ????return?0;??
  • }??
  • 答案:輸出兩行,分別是Base::doPrint和Derived::doPrint。在print中調(diào)用doPrint時,doPrint()的寫法和this->doPrint()是等價的,因此將根據(jù)實際的類型調(diào)用對應的doPrint。所以結(jié)果是分別調(diào)用的是Base::doPrint和Derived::doPrint2。如果感興趣,可以查看一下匯編代碼,就能看出來調(diào)用doPrint是從虛函數(shù)表中得到函數(shù)地址的。

    總結(jié)

    以上是生活随笔為你收集整理的C/C++面试题精选的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。