本篇根據(jù)各個公司的面試問的常見問題進(jìn)行總結(jié)。
公眾號回復(fù)“面試”,獲取pdf答案
1 變量的聲明和定義有什么區(qū)別 2 簡述 #ifdef、#else、#endif
和#ifndef
的作用3 寫出 int 、bool、 float
、指針變量與 “零值”比較的if
語句4 結(jié)構(gòu)體可以直接賦值嗎 5 sizeof
和strlen
的區(qū)別6 C 語言的關(guān)鍵字 static
和 C++ 的關(guān)鍵字static
有什么區(qū)別7 C 語言的 malloc
和 C++ 中的new
有什么區(qū)別8 寫一個 “標(biāo)準(zhǔn)”宏MIN 9 ++i
和i++
的區(qū)別10 volatile
有什么作用11 一個參數(shù)可以既是 const
又是volatile
嗎12 a
和&a
有什么區(qū)別13 用 C 編寫一個死循環(huán)程序 14 結(jié)構(gòu)體內(nèi)存對齊問題 15 全局變量和局部變量有什么區(qū)別?實(shí)怎么實(shí)現(xiàn)的?操作系統(tǒng)和編譯器是怎么知道的? 16 簡述 C、C++ 程序編譯的內(nèi)存分配情況 17 簡述 strcpy、sprintf
與memcpy
的區(qū)別18 請解析 (*(void (*)( ) )0)( )
的含義19 C語言的指針和引用和c++的有什么區(qū)別? 20 typedef
和define
有什么區(qū)別21 指針常量與常量指針區(qū)別 22 簡述隊列和棧的異同 23 設(shè)置地址為 0x67a9
的整型變量的值為0xaa66
24 編碼實(shí)現(xiàn)字符串轉(zhuǎn)化為數(shù)字 25 C 語言的結(jié)構(gòu)體和 C++ 的有什么區(qū)別 26 簡述指針常量與常量指針的區(qū)別 27 如何避免“野指針” 28 句柄和指針的區(qū)別和聯(lián)系是什么? 29 new/delete
與malloc/free
的區(qū)別是什么30 說一說 extern“C”
31 請你來說一下 C++ 中 struct
和class
的區(qū)別32 C++ 類內(nèi)可以定義引用數(shù)據(jù)成員嗎? 33 C++ 中類成員的訪問權(quán)限 34 什么是右值引用,跟左值又有什么區(qū)別? 35 面向?qū)ο蟮娜筇卣?/section> 36 說一說 c++ 中四種 cast
轉(zhuǎn)換37 C++ 的空類有哪些成員函數(shù) 38 對 c++ 中的 smart pointer
四個智能指針:shared_ptr,unique_ptr,weak_ptr,auto_ptr
的理解39 說說強(qiáng)制類型轉(zhuǎn)換運(yùn)算符 40 談?wù)勀銓截悩?gòu)造函數(shù)和賦值運(yùn)算符的認(rèn)識 41 在 C++ 中,使用 malloc
申請的內(nèi)存能否通過delete
釋放?使用new
申請的內(nèi)存能否用free
?42 用 C++ 設(shè)計一個不能被繼承的類 43 C++ 自己實(shí)現(xiàn)一個 String
類44 訪問基類的私有虛函數(shù) 45 對虛函數(shù)和多態(tài)的理解 46 簡述類成員函數(shù)的重寫、重載和隱藏的區(qū)別 47 鏈表和數(shù)組有什么區(qū)別 48 用兩個棧實(shí)現(xiàn)一個隊列的功能 49 vector
的底層原理50 vector
中的reserve
和resize
的區(qū)別51 vector 中的
size和
capacity的區(qū)別52 vector 中
erase方法與
algorithn中的
remove`方法區(qū)別53 vector
迭代器失效的情況54 正確釋放 vector
的內(nèi)存(clear(), swap(), shrink_to_fit())
55 list
的底層原理56 什么情況下用 vector
,什么情況下用list
,什么情況下用 deque57 priority_queue
的底層原理58 map 、set、multiset、multimap
的底層原理59 為何 map
和set
的插入刪除效率比其他序列容器高60 為何 map
和set
每次Insert
之后,以前保存的iterator
不會失效?61 當(dāng)數(shù)據(jù)元素增多時(從 10000 到 20000), map
的set
的查找速度會怎樣變化?62 map 、set、multiset、multimap
的特點(diǎn)63 為何 map
和set
的插入刪除效率比其他序列容器高,而且每次insert
之后,以前保存的iter
64 為何 map
和set
不能像vector
一樣有個reserve
函數(shù)來預(yù)分配數(shù)據(jù)?65 set
的底層實(shí)現(xiàn)實(shí)現(xiàn)為什么不用哈希表而使用紅黑樹?66 hash_map
與map
的區(qū)別?什么時候用hash_map
,什么時候用map
?67 迭代器失效的問題 68 STL
線程不安全的情況
公眾號回復(fù)“面試”,獲取pdf答案
點(diǎn)【在看】是最大的支持