为什么这个说法不是长阵
Why is this statement not changin the array?
本文关键字:为什么 更新时间:2023-10-16
int a[]={1,2,3,5};
int i=1;
a[++i]=a[i];
int j;
for(j=0;j<4;j++)
{
printf("%d",a[j]);
}
output:1235;
为什么输出是1225
而不是1335
.
我在代码块上执行了这个程序。在a[++i]=a[i]
,从右到左的分配将是他们的,导致a[2]=a[1]
。如果我错了,请纠正我。
因为a[++i]=a[i];
是未定义的行为。
尘埃落定的时间点,到目前为止已经看到的所有副作用都保证是完整的。C 标准中列出的序列点是:
在完整表达式的评估结束时(一个完整的 表达式是表达式语句,或任何其他表达式 不是任何较大表达式中的子表达式); 在 ||、&&、?: 和逗号运算符处;和 在函数调用中(在所有参数的计算之后,就在实际调用之前)。
该标准指出
在上一个序列点和下一个序列点之间,对象应具有其 通过表达式的计算最多修改一次存储值。 此外,访问先验值只能用于确定 要存储的值。
a[++i]=a[i]; // this is undefined
如果您只想更改数组的单个元素...通过直接引用它来做到这一点:
int a[]={1,2,3,5};
int i=1;
a[i]++; // this will increment the ith element of the array by 1
int j;
for(j=0;j<4;j++)
{
printf("%d",a[j]);
}
输出:
1335
a[++i]=a[i];
是未定义的行为。因为根据C99第6.5节第2段
在上一个序列点和下一个序列点之间,对象应具有其 通过评估最多修改一次存储值 表达式.72)此外,先验值应仅读取为 确定要存储的值.73)
=
不是序列点。见附件C。
您正在i
一次修改该值,但"应仅读取先前的值以确定要存储的值",就像您a[++i]
一样
查看脚注73)
以获取该段落内容的示例。
73)This paragraph renders undefined statement expressions such as
i = ++i + 1;
a[i++] = i;
while allowing
i = i + 1;
a[i] = i;
因此,结果将如何无法确定。对于不同的运行和/或跨不同的计算机,您可以获得不同的结果。这种表达式不应该在 C 编程中使用。
a[++i] = a[i]
是未定义的行为。 查找此演示文稿。
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 为什么在全局范围内使用"extern int a"似乎不行?
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 为什么会发生堆损坏
- 为什么使用 "this" 指针调用派生成员函数?
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 为什么比较运算符如此快速
- 为什么 Serial.println(<char[]>);返回随机字符?
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 为什么不;名字在地图上是按顺序排列的吗
- 我的字符计数代码计算错误.为什么
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 为什么野牛仍在使用"int yylex(void)",却找不到"int yylex(YYS
- 为什么 std::unique 不调用 std::sort?
- 既然存在危险,为什么项目要使用-I include开关
- 为什么在运行时没有向我们提供有关分段错误的更多信息?