C++語言相關的常見面試題目(二)

1.vector底層實現原理

以下是?std::vector?的一般底層實現原理:

內存分配:當創建一個?std::vector?對象時,會分配一塊初始大小的連續內存空間來存儲元素。這個大小通常會隨著?push_back()?操作而動態增加。

容量和大小:std::vector?有兩個重要的成員變量:容量(capacity)和大小(size)。容量指向當前已分配內存空間的大小,而大小則表示當前?std::vector?中元素的數量。

元素訪問:通過使用指針進行偏移來訪問數組中的元素。因為?std::vector?是一個線性連續結構,在使用迭代器或下標訪問時可以直接計算偏移地址。

動態擴展:當向?std::vector?添加新元素時,如果當前容量不足以容納新元素,就需要重新分配更大的內存空間,并將原始數據拷貝到新地址上去。這可能導致數據復制開銷較大。

push_back(const T& value):向 vector 尾部添加一個元素。pop_back():刪除 vector 尾部的一個元素。size():返回當前 vector 中元素的個數。capacity():返回當前 vector 的容量(即分配了多少內存空間)。resize(size_type n, const T& val = T()):改變 vector 的大小,并且可以指定新添加元素的默認值。clear():清空 vector 中所有元素,使其大小變為 0。empty():判斷 vector 是否為空,如果為空則返回 true,否則返回 false。迭代器相關方法:begin() 和 end(): 返回指向第一個和最后一個元素之后位置(尾部)的迭代器。
可以使用迭代器遍歷并訪問 vector 中的所有元素。
下標操作符重載[]: 通過下標訪問特定位置上的元素。

2. vector的內存增長機制

省流:內存只增加不減少,gcc每次增長會翻倍,vs會增加0.5倍?

3. vector中reserve和resize的區別

省流:省不了一點

4. vector為什么不能存儲引用?

引用是別名,不是對象,沒有實際地址,不能定義引用的指針,也不能定義引用的引用

這是一條吃飯博客,由挨踢零聲贊助。學C/C++就找挨踢零聲,加入挨踢零聲,面試不挨踢!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/41281.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/41281.shtml
英文地址,請注明出處:http://en.pswp.cn/web/41281.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

element-plus 的form表單組件之el-radio(單選按鈕組件)

單選按鈕組件適用于同一組類型的選項只能互斥選擇的場景,就是支持單選。單選組件包含以下3個組件 組件名作用el-radio-group單選組組件,子元素可以是el-radio或el-radio-button,v-mode綁定單選組的響應式屬性el-radio單選組件,la…

階段三:項目開發---搭建項目前后端系統基礎架構:任務9:導入空管基礎數據

任務描述 本階段任務是導入項目的基礎數據,包括空管基礎數據和離線的實時飛行數據(已經脫敏)。 任務指導 本階段任務需要導入兩種數據: 1、在MySQL中導入空管基礎數據 kongguan.sql空管基礎數據表說明: 1告警信息…

OpenCV直方圖計算函數calcHist的使用

操作系統:ubuntu22.04OpenCV版本:OpenCV4.9IDE:Visual Studio Code編程語言:C11 功能描述 圖像的直方圖是一種統計表示方法,用于展示圖像中不同像素強度(通常是灰度值或色彩強度)出現的頻率分布。具體來說…

對MsgPack與JSON進行序列化的效率比較

序列化是將對象轉換為字節流的過程,以便在內存或磁盤上存儲。常見的序列化方法包括MsgPack和JSON。以下將詳細探討MsgPack和JSON在序列化效率方面的差異。 1. MsgPack的效率: 優點: 高壓縮率: MsgPack采用高效的二進制編碼格式&…

Embedding理解

一、概念 Embedding 可以理解為一種將概念、物體或信息轉換為數字序列的數值表示方法。它是溝通兩個不同世界或領域的橋梁,能夠把各種類型的數據(如文本、圖像、視頻等)映射到一個向量空間中。 在這個向量空間里,相似的項目(例如語義上相近的單詞、相似的圖像或相關的視…

cs231n作業1——SVM

參考文章:cs231n assignment1——SVM SVM 訓練階段,我們的目的是為了得到合適的 𝑊 和 𝑏 ,為實現這一目的,我們需要引進損失函數,然后再通過梯度下降來訓練模型。 def svm_loss_naive(W, …

【Qt】Qt概述

目錄 一. 什么是Qt 二. Qt的優勢 三. Qt的應用場景 四. Qt行業發展方向 一. 什么是Qt Qt是一個跨平臺的C圖形用戶界面應用程序框架,為應用程序開發者提供了建立藝術級圖形界面所需的所有功能。 Qt是完全面向對象的,很容易擴展,同時Qt為開發…

從打印到監測:納米生物墨水助力3D生物打印與組織監測平臺?

從打印到監測:納米生物墨水助力3D生物打印與組織監測平臺? 在 3D 組織工程中,納米生物墨水是將納米材料與 ECM 水凝膠結合,以提高其打印性和功能性的重要策略。納米生物墨水可以增強水凝膠的機械性能、導電性、生物活性&#xff…

汽車報價資訊app小程序模板源碼

藍色實用的汽車報價,汽車新聞資訊,最新上市汽車資訊類小程序前端模板。包含:選車、資訊列表、榜單、我的主頁、報價詳情、資訊詳情、詢底價、登錄、注冊、車貸,油耗、意見反饋、關于我們等等。這是一款非常全的汽車報價小程序模板…

MNIST 數據集 ubyte 格式介紹

train-images-idx1-ubyte 文件是用于存儲 MNIST 數據集中手寫數字圖像數據的文件。與標簽文件類似,這個文件使用的是一種簡單而緊湊的二進制格式。具體的文件格式如下: 文件頭(Header): 文件頭部分包含了一些描述文件內…

Ubuntu 20版本安裝Redis教程,以及登陸

第一步 切換到root用戶,使用su命令,進行切換。 輸入: su - 第二步 使用apt命令來搜索redis的軟件包,輸入命令:apt search redis 第三步 選擇需要的redis版本進行安裝,本次選擇默認版本,redis5.…

Emacs 的優點及與 DE 的比較

一、引言 在編程領域,對于工具的選擇一直是開發者們熱議的話題。今天,我們來探討一下 Emacs 及其所具有的優點,并思考使用 Emacs 寫程序是否真的比使用集成開發環境(IDE)更方便。 二、Emacs 的優點 高度可定制性 可以…

mac如何安裝nvm

? vue項目開發,熱更新,webpack,前輩造的輪子:各類的工具,庫,像axios,qs,cookie等輪子在npm上可以拿來直接用,需要node作為環境支撐。 開發時同時有好幾個項目,每個項目的需求不同…

Tornado:高性能異步Web框架詳解

文章目錄 引言官網鏈接Tornado 原理1. 非阻塞I/O2. 異步編程3. 事件循環4. 輕量級 使用方法安裝Tornado創建一個簡單的Web服務器 優缺點優點缺點 結論 引言 在Web開發的廣闊領域中,處理高并發和實時性需求一直是開發者們面臨的挑戰。Tornado,作為一個由…

威綸通創建項目創建(輸入,輸出,畫面切換使用)

創建一個項目 1,打開軟件 2,創建項目,設置系統參數 增加設備,選擇好對應型號(有市面上80%設備) 3,修改頁面,選擇參數 4,創建新頁面 不能在已經編輯的頁面進行新增 5&a…

【HTML入門】第三課 - 標題、段落、空格

這一小節,我們說一些比較零散的知識,HTML課程中呢,其實就是一些標簽,正是這些標簽組成了前端網頁的各種元素,所以你也可以叫他們標簽元素。 像前兩節我們說的,html head body title meta style 。這些都是…

【考研】南郵歷年復試上機試題目與題解

【考研】南郵歷年復試上機試題目與題解 文章目錄 【考研】南郵歷年復試上機試題目與題解個人題目難度評估歷年上機題目PROB1002 求最值問題PROB1003 新對稱素數問題PROB1004 進制轉換PROB1005 涂色問題 (待補)PROB1006 最大公約數和最小公倍數PROB1007 斐波那契數列PROB1008 回…

解決Spring Boot中的數據庫連接池問題

解決Spring Boot中的數據庫連接池問題 大家好,我是微賺淘客系統3.0的小編,也是冬天不穿秋褲,天冷也要風度的程序猿! 1. 理解數據庫連接池的重要性 數據庫連接池在任何使用數據庫的應用程序中都起著至關重要的作用。它們管理和維…

解析Java中的動態代理與靜態代理的區別

解析Java中的動態代理與靜態代理的區別 大家好,我是微賺淘客系統3.0的小編,也是冬天不穿秋褲,天冷也要風度的程序猿! 1. 引言 代理模式是軟件開發中常用的一種設計模式,用于控制對其它對象的訪問。在Java中&#xf…

C#中的Task.Delay(2000).Wait() 與await Task.Delay(2000)

Task.Delay(2000).Wait() 和 await Task.Delay(2000) 在功能上看似相似,都用于等待一段時間(在這個例子中是2000毫秒),但它們在使用方式和背后的行為上存在一些關鍵差異。 .Result 是 Task 類的一個屬性,它用于獲取任務…