【C++grammar】左值、右值和將亡值

目錄

    • C++03的左值和右值
    • C++11的左值和右值
    • 將亡值

在C++03中就有相關的概念

C++03的左值和右值

通俗的理解:

(1) 能放在等號左邊的是lvalue
(2) 只能放在等號右邊的是rvalue
(3) lvalue可以作為rvalue使用

對于第三點可以舉個例子:
int x ;
x = 6; //x是左值,6是右值
int y ;
y = 6; //y是左值,6是右值
y = x; //x作為右值,所以左值是可以作為右值使用的

C++11對左值和右值做出了更加詳細的劃分。

C++11的左值和右值

表達值分為泛左值、右值;
泛左值分為左值和將亡值(涉及右值引用)
右值可分為純右值和將亡值(涉及右值引用)
在這里插入圖片描述

左值指定了一個函數或者對象(表達式計算得出的結果),它是一個可以取地址的表達式。
也就是說,如果一個函數或者對象可以取地址,那么他就是一個左值。

int lv1{ 42 }; // Object
int main() {int& lv2{ lv1 }; // Lvalue reference to Objectint* lv3{ &lv1 }; // Pointer to Object
}
int& lv4() { return lv1; } // Function returning Lvalue Reference

左值例子:

(1) 解引用表達式p
(2) 字符串字面量"abc"
(3) 前置自增/自減表達式 ++i / --i
(4) 賦值或復合運算符表達式(x=y或m
=n等)

純右值是不和對象相關聯的值(字面量)或者其求值結果是字面量或者一個匿名的臨時對象.
純右值例子:

(1) 除字符串字面量以外的字面量,比如 32, ‘a’

(2) 返回非引用類型的函數調用 int f() { return 1;}

(3) 后置自增/自減表達式i++/i–

(4) 算術/邏輯/關系表達式(a+b、a&b、a<<b)(a&&b、a||b、~a)(a==b、a>=b、a<b)

(5) 取地址(&x)

如:

72.0f
a–
x為一個整型變量,&x

左值可以當成右值使用

將亡值

將亡值也指定了一個對象,是一個將純右值轉換為右值引用的表達式:
&&這里不是邏輯與運算符,而是右值引用

int&& rvr1{ 22 }; // 右值引用可以引用純右值

我們先來看什么是左值引用:
a是個左值,b是a的引用,為左值引用。

int a = 1;
int& b = a;

如果a是個常量22,我們對其引用就會出錯:
如下:

int& b{22};		//錯!非常量左值引用不可引用純右值

為了解決這個問題,可以使用const 引用(常量左值引用)引用純右值:
這樣就能保證22(純右值)不會通過b修改,這樣b就相當于是22的別名。

const int& b{22};

當然還有另一種引用純右值的方法就是右值引用了:
通過右值引用可以使純右值的生存期增加,例如:
int&& rvr1{ 22 }; // 右值引用可以引用純右值
int rv2 =++rv1;
原本22在執行完第一個語句就會消亡,但是使用右值引用之后,就可以在后面的語句通過調用右值引用,繼續使用這個值了。

總例:

int prv(int x) { return 6 * x; } // pure rvalue int main() {const int& lvr5{ 21 }; // 常量左值引用可引用純右值int& lvr6{ 22 }; // 錯!非常量左值引用不可引用純右值int&& rvr1{ 22 }; // 右值引用可以引用純右值int& lvr7{ prv(2) }; // 錯!非常量左值引用不可引用純右值int&& rvr2{ prv(2) }; // 右值引用普通函數返回值rvr1 = ++rvr2; // 右值引用做左值使用}

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

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

相關文章

scala字符串的拉鏈操作_在Scala中對字符串進行操作

scala字符串的拉鏈操作Scala字符串操作 (Scala strings operation) A string is a very important datatype in Scala. This is why there are a lot of operations that can be done on the string object. Since the regular operations like addition, subtraction is not v…

九、池化層

一、Pooling layers Pooling layers官網文檔 MaxPool最大池化層下采樣 MaxUnpool最大池化層上采樣 AvgPool最大池化層平均采樣 例如&#xff1a;池化核為(3,3)&#xff0c;輸入圖像為(5,5)&#xff0c;步長為1&#xff0c;不加邊 最大池化就是選出在池化核為單位圖像中的最大…

[分享]SharePoint移動設備解決方案

老外寫的一個PPT&#xff0c;講SharePoint在移動領域的應用&#xff0c;2012年最新的&#xff0c;有iPad喲。/Files/zhaojunqi/SharePoint2010andMobileDevices.pdf 轉載于:https://www.cnblogs.com/zhaojunqi/archive/2012/04/12/2444712.html

十、非線性激活函數

一、ReLU torch.nn.ReLU(inplaceFalse)官網提供的API 其中inplace表示是否在對原始數據進行替換 由函數圖可以看出&#xff0c;負數通過ReLU之后會變成0&#xff0c;正數則不發生變化 例如&#xff1a;input -1&#xff0c;若inplace True&#xff0c;表示對原始輸入數據進…

最短公共子序列_最短公共超序列

最短公共子序列Problem statement: 問題陳述&#xff1a; Given two strings, you have to find the shortest common super sequence between them and print the length of the super sequence. 給定兩個字符串&#xff0c;您必須找到它們之間最短的公共超級序列&#xff0c…

單調棧 leetcode整理(二)

目錄為什么單調棧的時間復雜度是O(n)496. 下一個更大元素 I方法一&#xff1a;暴力方法二:單調棧哈希表739. 每日溫度單調棧模版解優化503. 下一個更大元素 II單調棧循環遍歷為什么單調棧的時間復雜度是O(n) 盡管for 循環里面還有while 循環&#xff0c;但是里面的while最多執…

Android中引入第三方Jar包的方法(java.lang.NoClassDefFoundError解決辦法)

ZZ&#xff1a;http://www.blogjava.net/anchor110/articles/355699.html1、在工程下新建lib文件夾&#xff0c;將需要的第三方包拷貝進來。2、將引用的第三方包&#xff0c;添加進工作的build path。3、&#xff08;關鍵的一步&#xff09;將lib設為源文件夾。如果不設置&…

QTP自傳之web常用對象

隨著科技的進步&#xff0c;“下載-安裝-運行”這經典的三步曲已離我們遠去。web應用的高速發展&#xff0c;改變了我們的思維和生活習慣&#xff0c;同時也使web方面的自動化測試越來越重要。今天&#xff0c;介紹一下我對web對象的識別&#xff0c;為以后的對象庫編程打下基礎…

leetcode中使用c++需要注意的點以及各類容器的初始化、常用成員函數

目錄1、傳引用2、vector使用初始化方法常用成員函數3、字符串string初始化方法常用成員函數4、哈希表 unordered_map初始化常用成員函數示例&#xff1a;計數器5、哈希集合 unordered_set初始化常用成員函數6、隊列 queue初始化成員函數7、棧stack初始化常用成員函數7、emplace…

Linq list 排序,Dictionary 排序

C# 對List成員排序的簡單方法 http://blog.csdn.net/wanzhuan2010/article/details/6205884 LINQ之路系列博客導航 http://www.cnblogs.com/lifepoem/archive/2011/12/16/2288017.html 用一句Linq把一個集合的屬性值根據條件改了&#xff0c;其他值不變 list去重 list.Where((x…

javascript Ajax 同步請求與異步請求的問題

先來看以下代碼&#xff1a; var flagtrue; var index0; $.ajax({url: "http://www.baidu.com/",success: function(data){flagfalse;} }); while(flag){index; } alert(index); 請問最后alert的index的結果是多少&#xff1f; 可能有人會說0唄。實際上卻沒那么簡單…

定義類的Python示例

The task to define a class in Python. 在Python中定義類的任務。 Here, we are defining a class named Number with an attribute num, initializing it with a value 123, then creating two objects N1 and N2 and finally, printing the objects memory locations and a…

十一、線性層

一、Linear Layers torch.nn.Linear(in_features, out_features, biasTrue, deviceNone, dtypeNone) 以VGG神經網絡為例&#xff0c;Linear Layers可以將特征圖的大小進行變換由(1,1,4096)轉換為(1,1,1000) 二、torch.nn.Linear實戰 將CIFAR-10數據集中的測試集二維圖像[6…

easyui plugin——etreegrid:CRUD Treegrid

昨天寫了一個koeasyui的同樣的實現&#xff0c;感覺寫的太亂&#xff0c;用起來十分麻煩&#xff0c;于是今天照著edatagrid&#xff0c;寫了一個etreegrid&#xff0c;這樣再用ko綁定就方便多了。 使用很簡單,$(tableId).etreegrid({idField:parentIdField:,treeField:,saveUr…

expr

expr在linux中 是一個功能非常強大的命令。通過學習做一個小小的總結。 1、計算字符串的長度。我們可以用awk中的length(s)進行計算。我們 也可以用echo中的echo ${#string}進行計算&#xff0c;當然也可以expr中的expr length $string 求出字符串的長度。舉 例[rootlocalhost …

leetcode 42. 接雨水 思考分析(暴力、動態規劃、雙指針、單調棧)

目錄題目思路暴力法動態規劃雙指針法單調棧題目 給定 n 個非負整數表示每個寬度為 1 的柱子的高度圖&#xff0c;計算按此排列的柱子&#xff0c;下雨之后能接多少雨水。 輸入&#xff1a;height [0,1,0,2,1,0,1,3,2,1,2,1] 輸出&#xff1a;6 解釋&#xff1a;上面是由數組…

chdir函數_PHP chdir()函數與示例

chdir函數PHP chdir()函數 (PHP chdir() function) The full form of chdir is "Change Directory", the function chdir() is used to change the current working directory. chdir的完整形式是“更改目錄” &#xff0c; 功能chdir()用于更改當前工作目錄。 Synt…

十二、Sequential

一、Sequential介紹 torch.nn.Sequential(*args) 由官網給的Example可以大概了解到Sequential是將多層網絡進行便捷整合&#xff0c;方便可視化以及簡化網絡復雜性 二、復現網絡模型訓練CIFAR-10數據集 這里面有個Hidden units隱藏單元其實就是連個線性層 把隱藏層全部展開整…

1064-快速排序

描述 給定輸入排序元素數目n和相應的n個元素&#xff0c;寫出程序&#xff0c;利用內排序算法中快速排序算法進行排序&#xff0c;并輸出排序最后結果的相應序列。 輸入 共兩行&#xff0c;第一行給出排序元素數目n&#xff0c;第二行給出n個元素&#xff0c;1≤n≤100000&…

社交問答:取代BBS的Web2.0革命

編者按&#xff1a;本文由樂維UP創始人俞越撰寫&#xff0c;你也可以點擊這里關注俞越的新浪微博。 BBS在中國的興起是在95年&#xff0c;之后以驚人的速度發展起來。從2011年開始&#xff0c;國內的問答社區也如當年的BBS一樣&#xff0c;大量涌現快速成長&#xff0c;大體分為…