【C++11】auto與decltype關鍵字使用詳解

系列文章目錄

C++11新特性使用詳解-持續更新


文章目錄

    • 系列文章目錄
    • 前言
    • 一、auto關鍵字
      • 1.根據變量的初始化表達式來推導變量的類型
      • 2.const與引用
    • 二、decltype關鍵字
      • 1.推斷表達式的類型
      • 2.const與引用
    • 三、總結


前言

auto和decltype是C++11引入的倆個重要的新關鍵字,用于在編譯期自動推導出變量或表達式的類型。極大提高代碼的可讀性和簡潔性,并且有助于減少類型轉換錯誤。


一、auto關鍵字

編程時常常需要把表達式的值賦給變量,這就要求變量申明時必須清楚知道表達式的類型。做到這點不容易或者根本做不到。為了解決這個問題,C++11引入auto關鍵字讓編譯器自動推導變量的類型。

1.根據變量的初始化表達式來推導變量的類型

auto a = 1; // a的類型為int  
auto b = 5.20; // b的類型為double  
auto c = "auto"; // c的類型為const char[6]  
auto person1 = Person(); // person1的類型為Person,并且自動初始化成員變量變量
auto person2 = Person{ "Fei", 30 }; // person2的類型為Person,并且根據指定的初始值初始化成員變量變量std::vector<int> vec = { 1, 2, 3, 4, 5 };
for (auto it = vec.begin(); it != vec.end(); ++it) {   // 在for循環中使用auto推導類型std::cout << *it << " ";
}

2.const與引用

使用引用其實是使用引用的對象。特別是當引用被當作初始值時,正在參與初始化的是引用對象的值。此時編譯器以引用對象的類型作為auto的類型。

int i = 10, &r = i;
auto aa = r;  //推導出aa類型是int:r是i的別名,i是int(正在參與初始化的是引用對象的值,以引用對象的值作為auto的類型)//auto一般會忽略頂層const,同時底層const則會被保留
const int ci = i, &cr = ci;
auto bb = ci;  //推導出bb類型是int(ci的頂層const特性被忽略了)
auto cc = cr;  //推導出cc類型是int(cr是ci的別名,ci本身是一個頂層const)
auto dd = &i;  //推導出cc類型是int*
auto ee = &ci;  //推導出cc類型是const int*(對常量對象取地址是一種底層const)//如果希望auto推斷出來的類型是一個頂層的const,需要明確指出
const auto ff = ci;  //推導出b類型是int//設置類型為auto的引用是,初始值中的頂層常量屬性任然保留
auto &gg = ci;  //推導出b類型是const int&

二、decltype關鍵字

希望從表達式的類型中推導除要定義的變量的類型,但是不想用該表達式的值初始化變量。為了滿足這各要求,C++11引入decltype關鍵字讓編譯器自動推導表達式的類型,而不用計算表達式的值。

1.推斷表達式的類型

int x = 10;
decltype(x) y;    //y的類型是intdouble foo();
decltype(foo()) z;  //z的類型是double,根據函數返回值類型推導

2.const與引用

decltype處理頂層const和引用的方法和auto不同。
如果表達式是一個引用類型,decltype會去除引用,推導出引用所引用的類型。
例如,對于表達式int& x, decltype(x)的推導結果是int,去除了引用。

需要注意的是,decltype推導出的類型會保留頂層const限定符和volatile限定符,不會去除它們。

const int cii = 10, &cjj = cii;
decltype(cjj) xx = 0;   //x的類型是const int&
decltype(cjj) yy = xx;   //x的類型是const int&,y綁定到x
//decltype(cjj) zz;  //錯誤: z是個引用,必須初始化int xxx = 0;
decltype(xxx) pp = 0;

三、總結

在不影響代碼可讀性的前提下可以盡可能的使用auto。復雜類型用auto,但是簡單內置類型就沒有必要使用auto了。總之避免過度使用auto和decltype,以保持代碼的可讀性和維護性。

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

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

相關文章

簡單幾步,借助Aapose.Cells將 Excel XLS 轉換為PPT

數據呈現是商業和學術工作的一個重要方面。通常&#xff0c;您需要將數據從一種格式轉換為另一種格式&#xff0c;以創建信息豐富且具有視覺吸引力的演示文稿。當您需要在幻燈片上呈現工作表數據時&#xff0c;需要從 Excel XLS 轉換為 PowerPoint 演示文稿。在這篇博文中&…

原理Redis-QuickList

QuickList **問題1&#xff1a;**ZipList雖然節省內存&#xff0c;但申請內存必須是連續空間&#xff0c;如果內存占用較多&#xff0c;申請內存效率很低。怎么辦&#xff1f; 為了緩解這個問題&#xff0c;我們必須限制ZipList的長度和entry大小。 **問題2&#xff1a;**但是…

[網鼎杯 2018]Fakebook

[網鼎杯 2018]Fakebook 打開環境出現一個登錄注冊的頁面 在登錄和注冊中發現 了地址欄出現變化&#xff0c;掃一波看看 看看robots.txt和flag.php 訪問robots.txt看看 再訪問user.php.bak <?php class UserInfo { public $name ""; public …

Head、Neck、Backbone介紹

在深度學習中&#xff0c;通常將模型分為三個部分&#xff1a;backbone、neck 和 head。 Backbone&#xff1a;backbone 是模型的主要組成部分&#xff0c;通常是一個卷積神經網絡&#xff08;CNN&#xff09;或殘差神經網絡&#xff08;ResNet&#xff09;等。backbone 負責…

ON1 Photo RAW 2024 for Mac——專業照片編輯的終極利器

ON1 Photo RAW 2024 for Mac是一款專為Mac用戶打造的照片編輯器&#xff0c;以其強大的功能和易用的操作&#xff0c;讓你的照片編輯工作變得輕松愉快。 一、強大的RAW處理能力 ON1 Photo RAW 2024支持大量的RAW格式照片&#xff0c;能夠讓你在編輯過程中獲得更多的自由度和更…

練習九-利用狀態機實現比較復雜的接口設計

練習九-利用狀態機實現比較復雜的接口設計 1&#xff0c;任務目的&#xff1a;2&#xff0c;RTL代碼3&#xff0c;RTL原理框圖4&#xff0c;測試代碼5&#xff0c;波形輸出 1&#xff0c;任務目的&#xff1a; &#xff08;1&#xff09;學習運用狀態機控制的邏輯開關&#xff…

【C++11】=default與=delete關鍵字使用詳解

系列文章目錄 C11新特性使用詳解-持續更新 文章目錄 系列文章目錄一、default關鍵字1. 為什么要引入default關鍵字2. 注意事項3. 使用default關鍵字有什么好處4.實例代碼 二、delete關鍵字1. 為什么要引入delete關鍵字2. 注意事項3. 使用場景3.1刪除默認構造函數3.2 刪除拷貝構…

2023.11.22 -數據倉庫的概念和發展

目錄 https://blog.csdn.net/m0_49956154/article/details/134320307?spm1001.2014.3001.5501 1經典傳統數倉架構 2離線大數據數倉架構 3數據倉庫三層 數據運營層,源數據層&#xff08;ODS&#xff09;&#xff08;Operational Data Store&#xff09; 數據倉庫層&#…

開發上門送桶裝水小程序要考慮哪些業務場景

上門送水業務已經有很長一段時間了&#xff0c;但是最開始都是給用戶發名片、貼小廣告&#xff0c;然后客戶電話訂水&#xff0c;水站工作人員再上門去送&#xff0c;這種人工記單和派單效率并不高&#xff0c;并且電話溝通中也比較容易出現偏差&#xff0c;那么根據這個情況就…

IT 領域中的主要自動化趨勢

48%的IT自動化流程屬于IT服務管理&#xff0c;過去一年中&#xff0c;IT運維自動化增長了272%。 IT部門從交付者轉變為戰略伙伴 今年的《工作自動化指數》數據顯示&#xff0c;自動化正在蔓延到組織的各個部門&#xff0c;越來越多的部門采用自動化&#xff0c;并且IT以外的員工…

一條命令徹底卸載Linux自帶多個版本jdk

一條命令徹底卸載Linux自帶多個版本jdk 檢查系統已經安裝的jdk rpm -qa | grep java卸載所有已經安裝的 jdk xargs 將參數逐個傳遞 將已安裝的 java 程序逐個當做參數傳遞給 rpm -e --nodeps rpm -qa | grep java | xargs rpm -e --nodeps再次檢查系統已經安裝的jdk rpm -qa | …

JS實現二分查找

最近在面試的時候被問到手寫實現二分查找&#xff0c;雖然二分查找很早就聽過&#xff0c;也知道實現原理&#xff0c;但是手擼起來&#xff0c;總是差點意思&#xff0c;正好復習一下。作為前端程序員&#xff0c;可能面試絕大部分公司不需要能寫很復雜的算法問題&#xff0c;…

Azure Machine Learning - 搜索中的語義排名

目錄 什么是語義排名&#xff1f;語義排名的工作原理如何收集和總結輸入語義排名的輸出如何對摘要進行評分 語義功能和限制 在 Azure AI 搜索中&#xff0c;“語義排名”通過使用語言理解對搜索結果重新排名來顯著提高搜索相關性&#xff0c; 本文概括性地介紹了語義排名工作原…

Nodejs JavaScript 字符串加密

情景 問題的場景是這樣的&#xff1a;我們需要在瀏覽器cookie中存儲用戶名&#xff0c;但又不想直接明文存儲&#xff0c;所以對它進行了簡單的加密存儲。 因為是簡單的加密&#xff0c;目的只是不希望明文存儲。我們使用了Base64 編碼&#xff0c;使得cookie里的存儲不可只讀…

Arthas 監聽 Docker 部署的java項目CPU占比高的信息

1、Linux上安裝Arthas wget https://alibaba.github.io/arthas/arthas-boot.jar2、docker ps 查看目標項目的容器ID 3、copy Arthas 到目標容器中 (注意有 &#x1f615; ) docker cp arthas-boot.jar d97e8666666:/4、進入到目標容器目錄中 docker exec -it d97e8666666 /b…

5-7求三種數的和

#include<stdio.h> int main(){double sum10;double sum20;double sum30;double sum;int i;for(i1;i<100;i){sum1sum1i;}printf("sum1結果是&#xff1a;%15.6f\n",sum1);for(i1;i<50;i){sum2sum2i*i;}printf("sum2結果是&#xff1a;%15.6f\n"…

TS是什么、為什么、怎么辦

TS是什么 javascript程序的靜態類型檢查器 為什么要用TS js編寫時在預期不同類型值的地方使用了某種類型的值&#xff0c;導致常見的類型錯誤 js只能提供動態類型&#xff0c;也就是運行一下代碼才能知道發生了什么&#xff0c;需要靜態類型的檢查 TS怎么用 1、安裝vscode…

連接服務器的腳本

對于記不住的服務器密碼且不愿用三方工具俺簡單寫了個腳本&#xff08;檢測下最近shell腳本的學習效果咋樣&#xff09; expect 是處理交互的一種腳本語言&#xff0c;spawn啟動指定進程 -> expect獲取指定關鍵字 -> send想指定進程發送指定指令 -> 執行完成后退出 sp…

Oracle:poor sql導致的latch: cache buffers chains案例

巡檢時&#xff0c;執行如下sql發現長會話&#xff1a; SELECT SE.SID,SE.SERIAL#,TO_CHAR(LOGON_TIME,YYYY-MM-DD HH24:MI:SS),SE.STATUS,SE.OSUSER,SE.MACHINE,SE.PROGRAM,SE.BLOCKING_SESSION, SE.SQL_ID,SE.PREV_SQL_ID ,SE.EVENT,SE.P1TEXT,SE.P1,SE.P2TEXT,SE.P2,SE.P3…

LeetCode1161. Maximum Level Sum of a Binary Tree

文章目錄 一、題目二、題解 一、題目 Given the root of a binary tree, the level of its root is 1, the level of its children is 2, and so on. Return the smallest level x such that the sum of all the values of nodes at level x is maximal. Example 1: Input:…