小甲鱼 发表于 2016-3-10 16:16:12

什么是 lvalue,什么是 rvalue?

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

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



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

……
      int i;

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

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

你也是这么想的,对吧?{:10_334:}

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

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)来理解是不全面的。

请尝试执行下边代码:

#include <stdio.h>

int main()
{
      int a = 5;

      ++(a++);

      return 0;
}
你会得到下边错误提示:



在这里如果你认为 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,即任何可读取的值都被认为是右值(非左值)。

魚粉 发表于 2016-8-30 14:58:44

算式的演示沒看懂

流月飞星 发表于 2016-12-15 22:34:02

厉害

Wenchao_Deng 发表于 2017-1-6 14:28:21

好好好

超凡天赐 发表于 2017-1-20 11:01:49

什么叫识别和定位一个存储位置的标识符

mhp0114 发表于 2017-2-15 09:20:50

get it

hello1217 发表于 2017-3-3 20:34:36

厉害

小甲鱼的二师兄 发表于 2017-3-15 10:54:58

厉害~()~

Dine 发表于 2017-4-17 23:34:29

懂一点点了

dnfpk001 发表于 2017-5-10 15:47:39

{:10_245:}

qtw1998 发表于 2017-5-21 14:00:47

{:10_256:}

598161264 发表于 2017-5-21 22:13:43

好文顶一下

a1294951692 发表于 2017-8-5 04:42:27

独我雅想 发表于 2017-8-12 19:04:24

感觉每次小甲鱼出的机试题目我都不会写{:9_221:}

骑着蜗牛狂奔 发表于 2017-8-23 16:35:25

{:10_266:}

jinbiao 发表于 2017-9-14 09:38:11

懂了一点点,感觉有点复杂

cyndiwants 发表于 2017-9-27 11:32:20

这个演示表示看不懂啊。老大

云中豆 发表于 2017-12-15 19:56:34

新技能get√

smilepower 发表于 2018-2-19 08:54:49

概念清晰了一点

cyl010001 发表于 2018-3-25 17:59:54

真是一个好文章 !
页: [1] 2 3 4 5 6 7 8 9 10
查看完整版本: 什么是 lvalue,什么是 rvalue?