指向C++中带有Consts的数组的指针和引用
Pointer and References to Array with Consts in C++
我很清楚const指针到指针的问题,我以为我知道发生了什么,但天哪,我错了。我想实现这个:
int* var[4];
const int* const (&refArray)[4] = var; //compile error
是的,我想保留数组,而不是转换为指针,是的,实际上我在代码中遇到了这个问题。所以我继续调查我能做什么和不能做什么,不久我意识到我不知道发生了什么:
int* var[4];
const int* const * ptr = var; //allowed
const int* const * (&refPtr_indirect) = ptr; //allowed
const int* const * (&refPtr) = var; //error
const int* const * const (&constRefPtr) = var; //allowed
int* const (&refArray)[4] = var; //allowed
const int* const (&refArray)[4] = var; //error
我能理解前四个,但后两个对我来说毫无意义。我确实看到第三个版本可能会起作用,我可以放弃reference
,但我真的希望保留数组类型。
任何帮助都是值得赞赏的,但希望它能包括为什么规则是这样的背后的推理。
您有一个指向(非常量)int
的四个指针数组。要将其视为指向const int
的四个指针的数组,需要执行类型双关。类型int [4]
和const int [4]
不同,对其中一个的引用不能引用另一个。
你能做的最好的事情就是对整个数组进行一个常量引用。在这种复杂的情况下,最好使用一些类型名称来进行管理:
typedef int* TheArray[4];
TheArray var;
const TheArray &ref = var;
这给了你这个:
ref[0]; // OK
ref[0] = nullptr; // error
*ref[0]; // OK
*ref[0] = 42; // OK
你的第五个版本是一样的,只是没有类型名称
int * const (&refArray) [4] = var;
对指向int
的四个指针的常量数组的引用。(常量数组与常量元素的数组相同)。
正如我在顶部所说,第六个版本不可能奏效;数组元素的类型不同,因此没有引用可以同时引用它们。
Angew得到了一些分数,但我认为问题在于:
无法将int*[n]
转换为const int*[n]
。
所以这是允许的:
int a[4];
const int (&b)[4] = a;
但以下情况并非如此:
int *c[4];
const int *(&d)[4] = c;
相关文章:
- 添加到数组指针
- C++语法差异:二维和一维数组(指针算术)
- 数组指针表示法C++(移动数组时)
- 复制后删除原始数组指针将前 3 个字节设置为 0
- C++访问指向结构的指针中的类数组指针
- C++编译时使用 constexpr 字符数组指针分配静态数组?
- std::flush可以用于将对象指针转换为其封闭数组指针吗
- 创建<int>对整数数组指针的矢量引用 (C++)
- 将 2D 数组指针传递给 C++ 中的函数
- 创建指针是否超过非数组指针的末尾,而不是从 C++17 中的一元运算符和未定义的行为派生?
- 队列数组指针 (C++)
- C++数组指针上的删除操作
- 对于循环不循环和检测字符数组 [指针和字符数组]
- 如何初始化数组指针对象
- 如何正确传递 2D 数组指针作为参数
- 从数组指针中获取怪异的数字
- 初始化std :: unique_ptr作为原始数组指针的初始化
- 将结构数组指针从C#传递到C
- STD :: Sort将数组指针设置为NULL
- C++数组指针错误无法将“int*”转换为“int**”