C++面試八股文之STL標(biāo)準(zhǔn)模板庫使用詳解
面試模擬
某日二師兄參加XXX科技公司的C++工程師開發(fā)崗位第21面:
面試官:用過STL嗎?
二師兄:(每天都用好嗎。。)用過一些。
面試官:你知道STL是什么?
二師兄:STL是指標(biāo)準(zhǔn)模板庫(Standard Template Library
),是C++區(qū)別于C語言的特征之一。
面試官:那你知道STL的六大部件是什么?
二師兄:分別是容器(container
)、迭代器(iterator
)、適配器(adaptor
)、分配器(allocator
)、仿函數(shù)(functor
)和算法(algorithm
)。
面試官:那你知道有哪些容器嗎?
二師兄:STL中容器的數(shù)量比較多,按照類型可以分為順序容器和關(guān)聯(lián)容器。
二師兄:順序容器主要有vector
、deque
、list
、forward_list
和array
。其中forward_list
和array
是C++11引入的。
二師兄:關(guān)聯(lián)容器主要有set
、map
、multiset
、multimap
、unordered_set
、unordered_map
、unordered_multiset
、unordered_multiamp
。其中后四種是C++11新引入的。
面試官:好的。那你知道迭代器分為哪些種類嗎?
二師兄:分別是輸入迭代器(Input Iterator
)、輸出迭代器(Output Iterator
)、前向迭代器(Forward Iterator
)、雙向迭代器(Bidirectional Iterator
)和隨機(jī)訪問迭代器(Random Access Iterator
)。
二師兄:其中輸入和輸出迭代器分別用于讀取和寫入數(shù)據(jù),前向迭代器只能向前訪問而不能向后訪問(forward_list
),雙向迭代器既可向前也可向后(list
),隨機(jī)訪問迭代器可以通過下標(biāo)訪問任何合法的位置(vector
)。
面試官:你知道適配器是做什么的嗎?
二師兄:適配器是一種設(shè)計模式。主要起到將不同的接口統(tǒng)一起來的作用。STL中的容器適配器如stack
和queue
,通過調(diào)用容器的接口,實現(xiàn)適配器所需的功能。
面試官:有了解過分配器嗎?
二師兄:分配器主要用于內(nèi)存的分配與釋放。一般容器都會自帶默認(rèn)分配器,很少會自己實現(xiàn)分配器。
面試官:有使用分配器做一些內(nèi)存分配的工作嗎?
二師兄:沒有。。。
面試官:知道仿函數(shù)是做什么用的嗎?
二師兄:是一個可執(zhí)行的對象,類型重載了operator()()
運算符。
struct Add { int operator()(int a, int b) {return a +b;} } int a = 42, b = 1024; auto sum = Add()(a,b); //OR Add add; auto sum = add(1,2);
面試官:STL中常見的算法有哪些?
二師兄:一般分為三類,查找、排序和數(shù)值操作。
二師兄:查找常用的有std::find
、std::find_if
、std::find_first_of
等。
二師兄:排序主要用std::sort
及其家族的一系列算法。
二師兄:數(shù)值操作主要用std::accumulate
求和。
面試官:那你知道STL六大部件之間的聯(lián)系嗎?
二師兄:(想了想)不是特別清楚。。。
面試官:好的,回去等通知吧。
讓我們回顧一下二師兄的表現(xiàn):
有使用分配器做一些內(nèi)存分配的工作嗎?
這里主要是問有沒有手寫過分配器:
template <typename T> class MyAllocator { public: typedef T value_type; MyAllocator() noexcept {} template <typename U> MyAllocator(const MyAllocator<U>&) noexcept {} T* allocate(std::size_t n) { if (n > std::size_t(-1) / sizeof(T)) throw std::bad_alloc(); if (auto p = static_cast<T*>(std::malloc(n * sizeof(T)))) return p; throw std::bad_alloc(); } void deallocate(T* p, std::size_t) noexcept { std::free(p); } };
實例中定義了一個名為MyAllocator
的模板類,它重載了allocate
和deallocate
運算符用于分配內(nèi)存和釋放內(nèi)存。示例中malloc
和free
函數(shù)來分配和釋放內(nèi)存,也可以用new
和delete
。
我們可以在allocate
和deallocate
中做很多事情,比如我們可以統(tǒng)計申請和釋放內(nèi)存的總量,可以申請一塊大內(nèi)存做內(nèi)存池等等。
知道STL六大部件之間的聯(lián)系嗎?
這個問題比較開放,需要對STL六大部件有一定的理解。首先是分配器,主要是為容器分配管理內(nèi)存的。其次是迭代器,是容器和算法的橋梁。再次是仿函數(shù),一般用作算法中,適配器提供各種粘合劑的功能,把不同部件之間的接口連接起來。
以上就是C++面試八股文之STL標(biāo)準(zhǔn)模板庫使用詳解的詳細(xì)內(nèi)容,更多關(guān)于C++面試STL標(biāo)準(zhǔn)模板庫的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
JetBrains?CLion永久激活超詳細(xì)教程(最新激活方法)
JetBrains?Clion?是一款專為?C/C++?開發(fā)所設(shè)計的跨平臺?IDE,本文適用?JetBrains?CLion?v2019.3/3.1/3.2/3.3?永久激活,附破解補(bǔ)丁和激活碼,可以永久激活?Windows、MAC、Linux?下的?CLion,下面給大家分享JetBrains?CLion永久激活超詳細(xì)教程,感興趣的朋友一起看看吧2023-01-01C++使用cjson操作Json格式文件(創(chuàng)建、插入、解析、修改、刪除)
本文主要介紹了C++使用cjson操作Json格式文件(創(chuàng)建、插入、解析、修改、刪除),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02C++中如何將operator==定義為類的成員函數(shù)
這篇文章主要介紹了C++中如何將operator==定義為類的成員函數(shù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01詳解Ubuntu18.04配置VSCode+CMake的C++開發(fā)環(huán)境
這篇文章主要介紹了詳解Ubuntu18.04配置VSCode+CMake的C++開發(fā)環(huán)境,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03