C++面試八股文:技術勘誤
在《C++面試八股文:C++中,設計一個類要注意哪些東西?》一文中,
#include <iostream>struct Foo{};struct Goo{ void f1(Foo& f){std::cout <<"non const function" << std::endl;} void f1(const Foo& f){std::cout <<"const function" << std::endl;} };int main(int argc, char const *argv[]){ Foo foo; Goo goo; goo.f1(foo); //無法透過編譯,error: ‘void Goo::f1(Foo)’ cannot be overloaded with ‘void Goo::f1(Foo)’ return 0; }
這裡的例子
f1
和
f2
方法的引數應該是
Foo f
和
const Foo f
,這才是頂層
const
。
在《C++面試八股文:std::string是如何實現的?》一文中,
有std::string過載的相關問題,我已經在 技術勘誤:《C++面試八股文:std::string是如何實現的?》 一文中做了詳細說明。
在《C++面試八股文:override和finial關鍵字有什麼作用?》一文中,final 誤拼為 finial。
同時,這張記憶體佈局圖也有錯誤,
應該是這樣的:
在《C++面試八股文:std::vector瞭解嗎?》一文中,
面試官:
push_back
和emplace_back
有什麼區別?
除了文中所說的不同點,還要一點:
emplace_back
可以傳入建構函式構造物件,而
push_back
只能複製或移動物件。
在《C++面試八股文:std::vector和std::list,如何選擇?》一文中,
以下程式碼的輸出是什麼?
#include <iostream>#include <list>int main(int argc, char const *argv[]){ std::list<int> li = {1,2,3,4,5,6}; for(auto it = li.begin(); it!= li.end(); ++it) { if(0 == *it % 2) li.erase(it); } for(auto& i : li) std::cout << i << " "; std::cout << std::endl; }
這裡給出的答案是有問題的:
erase
函式返回下一個有效迭代器,所以可以把if(0 == *it % 2) li.erase(it)
修改為if(0 == *it % 2) it = li.erase(it)
來解決這個問題。
這裡的erase返回的是下一個迭代器,然後++就是下下個迭代器,跳過了下個迭代器。但是上面程式碼中%2 == 0 也會跳過下個奇數,所以無法暴露這個問題。應該改成:
#include <iostream>#include <list>int main(int argc, char const *argv[]){ std::list<int> li = {1,2,3,4,5,6}; auto it = li.begin(); while(it!= li.end()) { if(0 == *it % 2) { it = li.erase(it); }else{ ++it; } } for(auto& i : li) std::cout << i << " "; std::cout << std::endl; }
在《C++面試八股文:什麼是建構函式?》一文中,
面試官:可以使用
virtual
修飾建構函式嗎?二師兄:不可以,因為建構函式在物件構造階段呼叫,虛表尚未建立,所以無法呼叫虛擬函式實現多型。
這裡的描述是有問題的, 虛表是在編譯期生成,在建構函式執行時,可能還沒有被初始化。所以無法呼叫虛擬函式實現多型。
在《C++面試八股文:什麼是空指標/野指標/懸垂指標?》一文中,
面試官:你知道
0/NULL/nullptr
三者之間的區別嗎?二師兄:雖然三者都能定義空指標,但三者型別不同。
二師兄:
0
是int
型別,NULL
在g++下是一個宏定義,而nullptr
是有型別的;
#define NULL ((void *)0)
這裡的定義也是有問題的,完整的定義如下:
#if defined (_STDDEF_H) || defined (__need_NULL)#undef NULL /* in case <stdio.h> has defined it. */#ifdef __GNUG__#define NULL __null#else /* G++ */#ifndef __cplusplus#define NULL ((void *)0)#else /* C++ */#define NULL 0#endif /* C++ */#endif /* G++ */#endif /* NULL not defined and <stddef.h> or need NULL. */#undef __need_NULL
在
GCC11
下,是
__null
, 型別是
long
。所以
sizeof(NULL) == 8
。
C++的標準繁雜,不同版本的標準可能有所出入。同時不同編譯器對標準的實現也不盡相同,這增加了C++學習者的負擔。
前路坎坷,吾輩不可因為荊棘密佈望而卻步。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70034822/viewspace-2992118/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 2022年Q3-2023年Q3全球后期和技術成長型投資額(附原資料表)
- 蘋果Mac電腦 ai技術影像編輯工具:Luminar Neo for Mac中文啟用版 支援M1人工智慧
- 行行AI公開課:飛書無程式碼平臺AI技術負責人鄧範鑫——從第一性原理看大模型Agent技術人工智慧
- 微機原理與介面技術-第八章常用介面技術
- 視野修煉-技術週刊第59期
- 老技術的新方向,看液冷伺服器如何重構資料中心產業
- PMP資源最佳化技術:資源平衡、資源平滑
- 廣州亞信技術攜AntDB資料庫入圍廣州市軟體和信創產業鏈重點企業代表名單資料庫
- 2023 SDC | 11大前沿技術議題,看雪第七屆安全開發者峰會於上海圓滿落幕!
- CLion 2023:探索C/C++的智慧之旅,開啟高效程式設計新篇章 mac/win版C++
- 為了簡寫這行程式碼,我竟使用靜態和動態編譯技術
- Gdi+列舉系統字型(忽略隱藏字型)C++原始碼C++
- 有HTTP代理池子,要怎麼快速搭建隧道代理?| 純技術分享
- 《資料安全與流通:技術、架構與實踐》新書釋出