C++中左值和右值的区别详解
目录
- 左值右值定义:
- 特性
- 左值引用, 右值引用
- 总结
左值右值定义:
左值指的是既能够出现在等号左边也能出现在等号右边的变量(或表达式),右值指的则是只能出现在等号右边的变量(或表达式).
int a; int b; a = 1; b = 2; a = b; b = a; a + b = 3; // 非法表示
右值分为纯右值和将亡值:
纯右值:临时变量和不跟对象关联的字面量值
将亡值:在确保其他变量不再被使用或即将销毁时,通过盗取的方式,可以避免内存空间的释放和分配,能够延长变量值的生命期。右值通常不具有名字,也只能通过引用的方式找到它的存在。
特性
首先, 对于基础类型,右值是不可被修改的(non-modifiable),也不可被 const, volatile 所修饰(cv-qualitification ignored)
其次,对于自定义的类型(user-defined types),右值却允许通过它的成员函数进行修改。
自定义类型应该设计得和内置类型尽量一样(所谓 value type,value semantic),但允许成员函数改变右值这个特性却有意无意使得自定义类型特殊化了。
对此,我们其实可以这样想:自定义类型允许有成员函数,而通过右值调用成员函数是被允许的,但成员函数有可能不是 const 类型,因此通过调用右值的成员函数,也就可能会修改了该右值
左值引用, 右值引用
引用类型本身并不拥有所绑定对象的内存,只是该对象的一个别名。
左值引用是具名变量值的别名,右值引用是不具名(匿名)变量的别名。
常量左值引用是个万能引用类型,可接受常量左值(带有const),非常量左值和右值对其初始化。常量左值引用的右值在其生命期内只能是只读的
E.g.1
int &a = 2; # 左值引用绑定到右值,编译失败 int b = 2; # 非常量左值 const int &c = b; # 常量左值引用绑定到非常量左值,编译通过 const int d = 2; # 常量左值 const int &e = c; # 常量左值引用绑定到常量左值,编译通过 const int &b =2; # 常量左值引用绑定到右值,编程通过
E.g.2
int a; int &&r1 = c; # 编译失败 int &&r2 = std::move(a); # 编译通过
总结
到此这篇关于C++中左值和右值的区别详解的文章就介绍到这了,更多相关C++左值和右值内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
相关推荐
-
一篇文章弄懂C++左值引用和右值引用
目录 1. 左值和右值 2. 左值引用 3. 右值引用 3.1 出现 3.2 概念 3.3 应用 3.3.1 右值引用绑定到左值上 3.3.2 std::move()本质 3.3.3 移动构造函数和移动赋值运算符 3.3.4 std::move()的一个例子 4. 补充-协助完成返回值优化(RVO) 5. 总结 篇幅较长,算是从0开始介绍的,请耐心看~ 该篇介绍了左值和右值的区别.左值引用的概念.右值引用的概念.std::move()的本质.移动构造函数.移动复制运算符和RVO. 1. 左值和右
-
浅谈C++左值引用和右值引用
实例如下: #include<iostream> #include<utility> #include<vector> using namespace std; int f(); int main() { vector<int>vi(100); int i=42; int &&r1=i;//error不能把右值引用绑到左值上 int &&r2=10; int &r3=i; int &r4=10;//error非
-
C++中左值和右值的区别详解
目录 左值右值定义: 特性 左值引用, 右值引用 总结 左值右值定义: 左值指的是既能够出现在等号左边也能出现在等号右边的变量(或表达式),右值指的则是只能出现在等号右边的变量(或表达式). int a; int b; a = 1; b = 2; a = b; b = a; a + b = 3; // 非法表示 右值分为纯右值和将亡值: 纯右值:临时变量和不跟对象关联的字面量值 将亡值:在确保其他变量不再被使用或即将销毁时,通过盗取的方式,可以避免内存空间的释放和分配,能够延长变量值的生命期.右
-
tensorflow: variable的值与variable.read_value()的值区别详解
问题 查看 tensorflow api manual 时,看到关于 variable.read_value() 的注解如图: 那么在 tensorflow 中,variable的值 与 variable.read_value()的值 到底有何区别? 实验代码 # coding=utf-8 import tensorflow as tf # Create a variable. w = tf.Variable(initial_value=10., dtype=tf.float32) sess =
-
Django中get()和filter()返回值区别详解
先上官方文档! filter(**kwargs) 返回包含与给定查找参数匹配的对象的新查询集. 简单来说,返回一个又对象组成的查询集合 get(**kwargs) 返回与给定查找参数匹配的对象,该对象应采用字段查找中描述的格式. 例子 例如在Model中有一个Order类,包含一个id字段,输入 id 为2019 字段的 id 1.get()方法 orders = Orders.objects.get(id=20190003) print(order) 先查看orders是什么,结果为 Orde
-
C语言入门篇--变量的左值和右值
目录 1.普通变量 2.指针变量 2.1初步理解 2.2深入理解 在看此块内容前可以先看看内存及地址相关内容,更容易理解. 1.普通变量 一个变量是有三个属性: 1.变量的空间. 2.变量的内容. 3.变量的地址. 空间即若干字节,内容即空间里放了什么,地址即变量对应的空间地址. #include <stdio.h> int main() { int a = 10;//定义变量a,开辟4个字节的空间. a = 20;//见下述文字解释 int b = a;//见下述文字解释 return 0;
-
C++左值与右值,右值引用,移动语义与完美转发详解
目录 C++——左值与右值.右值引用.移动语义与完美转发 一.左值和右值的定义 二.如何判断一个表达式是左值还是右值(大多数场景) 三.C++右值引用 四.std::move()与移动语义 五. 完美转发 总结 C++——左值与右值.右值引用.移动语义与完美转发 在C++或者C语言中,一个表达式(可以是字面量.变量.对象.函数的返回值等)根据其使用场景不同,分为左值表达式和右值表达式. 一.左值和右值的定义 1.左值的英文为locator value,简写为lvalue,可意为存储在内存中.有明
-
详解C++中的左值,纯右值和将亡值
目录 引入 一.表达式 二.值类别 三.左值 四.纯右值 五.将亡值 六.注意 引入 C++中本身是存在左值,右值的概念,但是在C11中又出现了左值,纯右值,将亡值得概念:这里我们主要介绍这些值的概念. 一.表达式 定义:由运算符和运算对象构成的计算式(类似数学中的算术表达式) 每个 C++ 表达式(带有操作数的操作符.字面量.变量名等)可按照两种独立的特性加以辨别:**类型和值类别 **(value category).每个表达式都具有某种非引用类型,且每个表达式只属于三种基本值类别中的一种:
-
C# 从枚举值获取对应的文本描述详解
C# 从枚举值获取对应的文本描述详解 有时枚举值在显示时,需要显示枚举值对应的文本串.一种方案是在调用的地方使用switch或者if来判断枚举值,然后赋给不同的文本串,但这样一来,如果有较多的地方都用到的时候就会比较麻烦.当然有人说,这种情况下,可以针对这种枚举值封装一个方法,然后来调用.那如果有多个枚举类型都有这样的需求呢?有没有什么比较通用的解决办法?有的. 这里需要用到Description属性,给每个枚举值都赋上一个该属性,然后在该属性中赋上要描述的文本串.比如 #region YesN
-
C语言中 值传递和指针传递实例详解
C语言中 值传递和指针传递实例详解 在C语言中,函数的参数和返回值的传递方式有两种:值传递和指针传递. 值传递和指针传递初学者总会有一种朦胧的感觉,所以建议把指针传递的概念摸透,才能熟练应用. 值传递示例:x其实是n的一份临时拷贝,所以并不会改变n的值. #include <stdio.h> #include <windows.h> void Fun(int x) { x = 1; } int main() { int n = 2; Fun(n); printf("%d\
-
对Python中DataFrame选择某列值为XX的行实例详解
如下所示: #-*-coding:utf8-*- import pandas as pd all_data=pd.read_csv("E:/协和问答系统/SenLiu/熵测试数据.csv") #获取某一列值为xx的行的候选列数据 print(all_data) feature_data=all_data.iloc[:,[0,-1]][all_data[all_data.T.index[0]]=='青年'] print(feature_data) 实验结果如下: "C:\Pro
-
对Tensorflow中权值和feature map的可视化详解
前言 Tensorflow中可以使用tensorboard这个强大的工具对计算图.loss.网络参数等进行可视化.本文并不涉及对tensorboard使用的介绍,而是旨在说明如何通过代码对网络权值和feature map做更灵活的处理.显示和存储.本文的相关代码主要参考了github上的一个小项目,但是对其进行了改进. 原项目地址为(https://github.com/grishasergei/conviz). 本文将从以下两个方面进行介绍: 卷积知识补充 网络权值和feature map的可
随机推荐
- 实例详解AngularJS实现无限级联动菜单
- javascript 写类方式之三
- Vue-router结合transition实现app前进后退动画切换效果的实例
- javascript实现选中复选框后相关输入框变灰不可用的方法
- PHP面向对象程序设计之类常量用法实例
- PHP图像处理之使用imagecolorallocate()函数设置颜色例子
- Python网络编程中urllib2模块的用法总结
- Android获取联系人姓名和电话代码
- js事件冒泡、事件捕获和阻止默认事件详解
- JavaScript中有关一个数组中最大值和最小值及它们的下表的输出的解决办法
- js函数般调用正则
- JS 事件绑定函数代码
- 彻底理解Java中的ThreadLocal
- 安卓自定义流程进度图控件实例代码
- Java中Arraylist动态扩容方法详解
- java 获取日期的几天前,几个月前和几年前的实例
- PHPExcel中文帮助手册|PHPExcel使用方法(分享)
- Android so库的热更新问题
- Vue父子模版传值及组件传值的三种方法
- Linux 命令find之查找文件的示例