指针的地址与指针的引用
Address of a pointer vs Reference to a pointer
我写了下面的代码:
int* p = new int(7);
std::cout << p << std::endl; //output: 0096FAB4
std::cout << &p << std::endl; //output: 0096FA90
为什么输出不同?
c++中的每个对象都由该对象的物理位置地址表示。如果你创建了一个地址类型int *p = new int(7);所以当你调用std::cout <<p & lt; & lt;std:: endl;它将输出内存中单元格的地址,即数字7的地址所在的位置。当你调用std::cout <<和p & lt; & lt;std:: endl;因此,它将输出内存中数字7所在单元格的物理地址。
结论:
- //输出:0096FAB4为整数7的地址的地址
- //输出:0096FA90是整数7的物理地址
的例子:
- 如果我们在内存中查找地址0096FAB4,我们将看到0096FA90
- 如果我们在内存中查找地址0096FA90,我们将看到00000007
相关文章:
- 如何使用基类指针引用派生类成员
- 将常量指针引用绑定到非常量指针
- 如果非动态变量被指针引用,何时超出范围?
- 转换指针引用的字符串
- 指针引用的生存期(以 C++为单位)
- 从 unique_ptr::get 发送指针作为指针引用进入函数
- 指针/引用的 CLion 格式
- 使用模板专用化来比较指针引用
- 如何保存指向抽象基类的指针/引用,但在 c++ 中仍然可以复制
- C++初始化指针/引用/复制细微差别
- 用数组或指针引用函数?
- 指针范围问题和返回类中封装的指针向量内的指针引用
- 强制转换为指针引用是否会导致未定义的行为
- 访问由 void 指针引用的结构的成员
- C 为什么当先前的步骤引发异常时,std :: shared_ptr的指针引用会被破坏
- 动态指针引用数组由三元运算符返回值,但有异常
- 悬空指向 int 和 char* 常量的指针/引用
- C++ 二维数组和指针引用
- 通过使用指针/引用,在C++中使用向量加快计算速度
- C++非类型模板模板到函数指针/引用