将常量指针引用绑定到非常量指针
Binding a const pointer reference to a non-const pointer
int val2 = 38;
int *ptr = &val2;
const int *&ptrRef = ptr; // ERROR
int i = 92;
int &ref_i = i;
const int &ref_i2 = ref_i; // OK
为什么我不能有一个引用非常量指针的常量引用?我认为,如果您访问constptrRef
标识符,它会将val2
视为const。当您访问ptr
时,它将把val2
视为非常数。这适用于代码的底部,所以我不明白为什么它不适用于指针。
East const使其更加清晰:
int const * & ptrRef = ptr; // ERROR
指针是常量。然而,ptr
是另一种类型。不能将引用绑定到其他类型。它需要转换,使初始化器成为临时的(ptr
转换为int const*
(。
现在,有一个更令人困惑的问题:const引用可以绑定到临时值,延长它们的生存期:为什么const引用会延长右值的生存期?
例如,它们允许函数接受
const&
的参数,并且仍然可以用临时调用:void foo(std::string const&); foo("foor"s+"bar"s); // still ok
我认为,你的问题归结为一个简单的拼写错误。如果您想要一个对非常量指针的常量引用,请使用以下内容:
int* const& ptrRef = ptr; // no error
这将ptrRef声明为对非常量指针的常量引用。另一个可能更干净的选择是引入typedef:
using intptr = int *;
const intptr& ptrRef = ptr;
此外,您可以完全放弃手动指定类型的业务:
const auto& ptrRef = ptr; // no error
而且,如果这是你想要的,这也会起作用(就像在编译中一样(:
const int* const& ptrRef = ptr; // no error
最新的位声明对常量指针的常量引用。
相关文章:
- 将常量指针引用绑定到非常量指针
- 如何使用数据对象上的常量指针初始化类
- C++中的指针和常量问题不大
- 为什么我收到"从常量指针到指针的转换无效?
- 当成员值从指针更改为非指针时,C++常量问题
- 使用双指针传递 2D 常量数组
- C++/QT:使用指向私有成员的常量指针作为只读数据共享
- 空指针常量 (nullptr)、空指针值和空成员指针值之间有什么区别?
- 模板推导:为什么函数指针模板定义在常量和/或引用时不匹配?
- 初始化指针的常量向量
- 区分接受常量参数的函数引用/指针和与函数参数同名的非常量参数
- 什么是常量指针常量引用类型的参数?(const X* const & p)
- 无法将"常量指针常量"传递给常量引用
- C++:如何创建一个临时对象,包含一个指针 - 常量或非常量,具体取决于上下文
- 具有函数指针常量数组的 C++ 模板化静态类
- 这个constexpr整数不是空指针常量吗
- 使指针常量C++
- C++11在stl容器中共享指针常量
- 空指针常量转换为右值
- 在参考 (T&) 和常量指针 (T* 常量) 之间进行选择