鱼C论坛

 找回密码
 立即注册
查看: 75897|回复: 227

[扩展阅读] 什么是 lvalue,什么是 rvalue?

    [复制链接]
发表于 2016-3-10 16:16:12 | 显示全部楼层 |阅读模式
零基础入门学习C语言封面
《零基础入门学习C语言》
小甲鱼 著
立即购买

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
什么是左值(lvalue)和右值(rvalue)?


随着学习的深入,你会经常看到 lvalue 这个词。一般出现在诸如各种、书籍中,更频繁遇到的是在你的错误提示中:

搜狗截图20160310151609.png

一般你会看到这个是因为你的代码这么写:

  1. ……
  2.         int i;

  3.         5 = i;
  4. ……
复制代码

一些朋友想当然的就觉得 lvalue 指的就是赋值运算符左边的那个值,而 rvalue 当然就是右边那个值啦。

所以我们亲切的称呼它们为“左值”和“右值”。

你也是这么想的,对吧?

事实上这样理解并不全面,并且常常容易犯思想上的错误……

OK,今天小甲鱼就尝试给 lvalue 正名!

首先,我们找到 C 语言的作者问问究竟,他是这么说的:

《The C Programming Language》

"An object is a manipulatable region of storage; an lvalue is an expression referring to an object.

...

The name 'lvalue' comes from the assignment expression E1 = E2 in which the left operand E1 must be an lvalue expression."

看到这里,大家就会说了,这不明摆着吗?人家作者都说了,E1 = E2,这个 E1 就是 lvalue(左值),你还闹腾个啥?

因为 C 语言是在不断发展的,毕竟老头的这本书说的是 C 语言的原型,自 1988 年第二版之后就没有再出新版了。而 C 的标准则经历了 K&R C,C89,C90,C99,C11 的迭代……

好吧,我们找来了目前最广泛使用的 C99 标准:

The name "lvalue" comes originally from the assignment expression E1 = E2, in which the left operand E1 is required to be a (modifiable) lvalue. It is perhaps better considered as representing an object "locator value". What is sometimes called "rvalue" is in this International Standard described as the "value of an expression".

这里说的很清楚了,lvalue 这个名字最初确实来自于 E1 = E2(E1 就是那个可改变的左值)。但更合理的解释应该是将 lvalue 理解为 locator value(特定位置的值),rvalue 则应该是 value of an expression(表达式的值)。

所以,单纯用左边(left-value)和右边(right-value)来理解是不全面的。

请尝试执行下边代码:

  1. #include <stdio.h>

  2. int main()
  3. {
  4.         int a = 5;

  5.         ++(a++);

  6.         return 0;
  7. }
复制代码

你会得到下边错误提示:

搜狗截图20160310161121.png

在这里如果你认为 lvalue 只是赋值运算符左边那个值,那这个错误提示就无法理解了。

但是如果你知道 lvalue 是用于识别或定位存储位置的标识符,那么就好解释了:

(a++) 是先将变量 a 的值(5)做为整个表达式的值返回,再将 a 自增 1(类似于 a = a + 1)。

所以这里 ++(a++); 相当于 ++(5), a = a + 1;

那当然要报错啦,5 是一个常量,当然不能给你 5 = 5 + 1 咯~


好了,差不多是这样了,谢谢大家花时间听小甲鱼扯淡~

重要的内容要重复强调:C 语言的术语 lvalue 指用于识别或定位一个存储位置的标识符。(注意:左值同时还必须是可改变的)

噢,对了,说了这么多,应该说说 rvalue 了吧?

其实 rvalue 的发明完全是为了搭配 lvalue,rvalue 你可以理解为 readable value,即任何可读取的值都被认为是右值(非左值)。

点评

nb  发表于 2022-12-3 16:42

评分

参与人数 27荣誉 +103 鱼币 +82 贡献 +51 收起 理由
L1nlinI + 3 无条件支持楼主!
康康要努力~ + 1
野蛮娘炮 + 5 + 5 + 3 感谢楼主无私奉献!
断弦冷訫 + 1 + 1 感谢楼主无私奉献!
Crory + 5 + 3 + 3 鱼C有你更精彩^_^
叶落了 + 1 + 1 + 2
六月的猫 + 5 + 5 + 3
cufml + 5 + 5 + 3
念123 + 5 + 5 + 3
乙烯依旧 + 3 六六六

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2025-9-25 17:10:39 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2025-8-19 14:33:57 | 显示全部楼层
get
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2025-5-5 20:29:30 | 显示全部楼层
嘻嘻
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2025-3-18 23:38:51 | 显示全部楼层
返回5是说明,没有a变量的存储空间了,是吗?就只有一个数值,一个常量,是吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-9-6 11:09:16 | 显示全部楼层
伟大的小甲鱼
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-9-5 12:50:33 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2024-6-21 08:08:55 | 显示全部楼层
上文中++(a++)可看成:
a++ = a++ + 1
a++就在左边啦
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-10 22:46:20 | 显示全部楼层
emm,半懂吧
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-3-25 12:32:01 | 显示全部楼层
牛逼的解释
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-1-20 00:41:52 | 显示全部楼层
我感觉更为准确的说左值包括可修改的左值。

因为取址符(&)作用于左值,&也可作用于数组名,而数组名是不可修改的,故左值中也有可修改和不可修改这一说!


个人见解
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-1-7 21:50:29 | 显示全部楼层
超凡天赐 发表于 2017-1-20 11:01
什么叫识别和定位一个存储位置的标识符

变量
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-21 08:51:00 From FishC Mobile | 显示全部楼层
努力学习,天天向上
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-10-27 20:33:57 | 显示全部楼层
总结:  
C 语言的术语 lvalue 指用于识别或定位一个存储位置的标识符。(注意:左值同时还必须是可改变的)

rvalue 的发明完全是为了搭配 lvalue,rvalue 你可以理解为 readable value,即任何可读取的值都被认为是右值(非左值)。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-10-3 11:08:50 | 显示全部楼层
好好好
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-10-1 09:44:32 | 显示全部楼层
厉害!!!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-8-15 21:01:09 | 显示全部楼层
涨知识了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-8-1 21:52:40 | 显示全部楼层
本帖最后由 老妮可 于 2023-8-1 21:54 编辑

.
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-5-18 19:06:17 | 显示全部楼层
懂了懂了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-5-7 17:05:43 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-5-3 15:31:06 | 显示全部楼层
总之变量写左边应该没错吧
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-10-28 05:00

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表