全局变量增量在 C++ 中的工作原理
how does global variable increment work in c++
#include <iostream>
int counter = 0;
int f(){
return counter++;
}
int main(){
std::cout << f(); //output = 0
std::cout << f()+f(); // output = 1;
return 0;
}
这可能是一个愚蠢的问题,但为什么在第一种情况下f()
不等于 1 而不是 0?我以为counter++
和counter = counter + 1
一样?
No. counter++
更接近(counter = counter + 1) - 1
<</p>
这是因为后缀和前缀表示法之间的差异。在后缀表示法中,这是您当前拥有的,它保存变量的副本,然后为当前调用以下的任何调用递增变量,但在当前调用时,它看起来保持不变。
这就是为什么当我们std::cout << f(); //output = 0
它输出 0 时,因为计数器只会在此行之后递增。如果将 f 更改为:
int f() { return ++counter; }
您将看到预期的结果。
首先,您确定f() + f()
结果1
吗?我认为应该是3
.
关于您的主要问题:
后递增适用于原始值的副本。所以 f(( 中的函数充当:
int f()
{
int temp = counter;
counter = counter + 1;
return temp;
}
或者正如@kmkaplan巧妙地指出的那样:
int f()
{
return (counter = counter + 1 ) - 1;
}
它类似于以下语义:
int f = 0;
cout << f++; // f original value is first displayed.
cout << ++f; // f is incremented then displayed.
一般来说,我更喜欢使用 ++n 而不是 n++,除非程序逻辑需要相反的情况。
相关文章:
- QSqlquery prepare()和bindvalue()不工作
- 导入库可以跨dll版本工作吗
- 以螺旋方式打印矩阵的程序.(工作不好)
- 对象指针在c++中是如何工作的
- 为什么在Windows上的VS 2019和Clang 9中"size_t"在没有标题的情况下工作
- VSOMEIP-2个设备之间的通信(TCP/UDP)不工作
- 为字符串中每 N 个字符插入空格的函数没有按照我认为的方式工作?
- C++为线程工作动态地分割例程
- 为什么我的 std::ref 无法按预期工作?
- 布尔比较运算符是如何在C++中工作的
- SampleConsensusPrerejective(ext.RANSAC)是如何真正工作的
- 不确定要在我的main中放入什么才能使我的代码正常工作
- 为什么std::condition_variable notify_all的工作速度比notify_one快(对于随机请
- <<操作员在下面的行中工作
- 有人能解释一下为什么下界是这样工作的吗C++的
- ExtractIconEx:可以工作,但偶尔会崩溃
- C++中的memset函数工作不正常
- 当我在第一个循环中使用"auto"时,它工作正常,但是使用"int"它会给出错误,为什么?
- 链表c++插入,所有情况都已检查,但没有任何工作
- 为什么stream::忽略未按预期工作