"x += x--"之后的 x 是什么?
What is x after 'x += x--'?
执行下面的代码后发生了什么x;
int x = 10;
x += x--;
我期待结果 19(将 x 加到 x,然后将 x 减少 1(,但结果 20。它在窗帘后面是如何工作的? 谢谢你的回答。
在这种情况下,行为在 C++17 之前是未定义的,例如,参见 https://en.cppreference.com/w/cpp/language/eval_order#Undefined_behavior ,所以如果你的编译器不符合它,测试或试图理解它是没有用的:它将取决于编译器的实现,甚至版本。
如果您的编译器符合 C++17,则可以保证在简单或复合赋值(=
或例如+=
分别(在评估左侧之前,将处理右侧的所有副作用。
在您的情况下,x--
被评估为10
并设置x=9
作为其副作用,然后计算机将10
添加到x=9
,从而导致x=19
。
感谢Michał的更正,我将其纳入答案。
使用较旧的 c++ 可能无法完成这项工作,因为根据旧标准,行为实际上被定义为未定义。(感谢@LightnessRacesinOrbit(
如果您只是尝试具有最新版本的在线编译器,它可以正常工作,结果如您所期望的那样是 19(x+=x--
与x= x+x--
相同。这意味着要获得新的"x",它必须将旧的"x"+旧的"x"相加-1。所以它会做x+(x--)
,这是x=10+(9)
。
在这里尝试一下: 跟:
#include <iostream>
using namespace std;
int main()
{
int x = 10;
x += x--;
cout<<x<<endl;
}
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- C++避免重复声明的语法是什么
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- C++中名称篡改的目的是什么
- 在 c++ 中拥有一组结构的正确方法是什么?
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 是什么阻止DOMTimerCoordinator::NextID进入无休止的循环
- 派生类销毁的最佳实践是什么
- 这个语法std::class<>{}(arg1, arg2) 在C++中是什么意思?
- 通过JNI传递数据数组的最快方法是什么
- "using namespace std;"在C++的作用是什么?
- 在两台机器之间进行时间戳的最佳c++chrono函数是什么
- 文件系统:复制功能的速度秘诀是什么
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 使用QQuickFramebufferObject时同步数据的最佳方式是什么
- 是什么原因导致它无法编译?它是声明签名还是在函数本身的实现中
- 使用不同的CRT将新的C++代码与旧的(二进制)组件隔离开来的最佳方法是什么