带有函数的 c++ 中的引用
References in c++ with function
任何人都可以详细说明此代码中的引用行为以及为什么它在第一行打印 12 而不是 11。
下面是代码
http://ideone.com/l9qaBp
#include <cstdio>
using namespace std;
int &fun()
{
static int x = 10;
x++;
return x;
}
int main()
{
int *ptr=&fun();
int *ptr1=&fun();
printf("%p %p t %d %d",(void*)ptr,(void*)ptr1,*ptr,*ptr1);
return 0;
}
代码的输出为
134519132 134519132 12 12
而不是 11 我明白当第二次调用时应该打印 12
ptr
和ptr1
指向同一个变量static int x
。第二次调用将 static int x
的值更改为 12
,然后你通过取消引用ptr
和ptr1
打印出该值,相同的结果将被打印出来。
fun(( 返回的 int 引用对于两个调用都是相同的(引用到
静态 x(,因此该引用的地址对于两个调用都是相同的。 因此,该相同地址的最终取消引用是当前相同的值。
您的错误似乎在于认为printf()
一可用就会打印*ptr
。它没有; 在计算ptr
和ptr1
之前,不会调用printf()
。由于 ptr
和 ptr1
都指向相同的内存位置,这是一个静态变量,并且在第一次调用 fun()
和第二次调用后更新该位置,因此地址保存该值。
static
变量具有生存期范围,并存储在静态分配的内存中。这意味着函数内static
局部变量的存储不会在调用堆栈上分配和释放。
一旦x
在编译时初始化,x
的值就会存储在函数fun
的调用之间。
由于C++语句是按顺序执行的,因此printf
将在调用给定行中的两个函数调用后执行
int *ptr=&fun();
int *ptr1=&fun();
因此,x
的值将在执行printf
语句之前12
。
请记住
int *ptr=&fun();
int *ptr1=&fun();
不等同于
int& (*ptr)() = &fun;
int& (*ptr1)() = &fun;
在第二个代码段中,ptr
和 ptr1
都保存函数 fun
的地址。在这种情况下,您需要直接调用函数或将这些指针用作
int a = ptr();
int b = ptr1();
在此调用值之后,a
和 b
将12
。
相关文章:
- 将对象数组的引用传递给函数
- 什么时候在C++中返回常量引用是个好主意
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 何时在引用或唯一指针上使用移动语义
- 如何在c++中使用引用实现类似python的行为
- 编译C++时未定义的引用
- Ctypes wstring通过引用传递
- c++r值引用应用于函数指针
- 理解c++中的引用
- C++取消引用指针.为什么会发生变化
- 如何修复此错误:未定义对"距离(浮点数,浮点数,浮点数,浮点数,浮点数)"的引用
- 我的项目不会像"undefined reference to `grpc::g_core_codegen_interface'"那样使用未定义的引用错误进行编译
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 强制转换为引用类型
- 引用一个已擦除类型(void*)的指针
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 具有默认值的引用获取函数
- 如何使用基类指针引用派生类成员
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 如何引用基类的派生类?