通过这样的常量指针修改非常量指针是合法的
Is is legal to modify a nonconst pointer through a const one like this?
考虑以下函数:
void f(int const* p)
{
*const_cast<int*>(id(p)) = 0;
}
假设f
总是将int*
作为参数,这是合法的事情吗?我不是在问这是否是一件好事,我只是想要一个严格正式的答案。
让我有点担心的是,如果你能做到这一点,优化器在利用常量方面会更加困难。考虑一个更复杂的例子:
// identity, always returns what it gets
uintptr_t id(uintptr_t p)
{
static unsigned int const ar[5] {0x12345678, 0x87654321, 0x02468ACE, 0xECA86420, 0x88888888};
for (size_t i = 0; i < 5; ++i)
p ^= ar[2*i % 5];
for (size_t i = 0; i < 5; ++i)
p ^= ar[3*i % 5];
return p;
}
void f(int const* p)
{
uintptr_t q = id(reinterpret_cast<uintptr_t>(p));
*reinterpret_cast<int*>(q) = 0;
}
这也合法吗?如果没有,将参数更改为int* p
会使其合法吗?
如果指向的值实际上是非常量,这是合法的,这就是为什么我们首先要const_cast
。如果值实际上是常量并且您抛弃了const
,则未定义。
如果f
总是被赋予一个int*
那么为什么不直接宣布f
采取一个非常量呢?或者,您可以提供重载:
void f(int const* a)
void f(int *a)
这样编译器将调用正确的版本,用户将看到您的意图是什么。调用第一个版本并让它更改值可能会让任何调用f
的人感到惊讶。
相关文章:
- 将常量指针引用绑定到非常量指针
- 如何使用数据对象上的常量指针初始化类
- C++中的指针和常量问题不大
- 为什么我收到"从常量指针到指针的转换无效?
- 当成员值从指针更改为非指针时,C++常量问题
- 使用双指针传递 2D 常量数组
- C++/QT:使用指向私有成员的常量指针作为只读数据共享
- 空指针常量 (nullptr)、空指针值和空成员指针值之间有什么区别?
- 模板推导:为什么函数指针模板定义在常量和/或引用时不匹配?
- 初始化指针的常量向量
- 区分接受常量参数的函数引用/指针和与函数参数同名的非常量参数
- 什么是常量指针常量引用类型的参数?(const X* const & p)
- 无法将"常量指针常量"传递给常量引用
- C++:如何创建一个临时对象,包含一个指针 - 常量或非常量,具体取决于上下文
- 具有函数指针常量数组的 C++ 模板化静态类
- 这个constexpr整数不是空指针常量吗
- 使指针常量C++
- C++11在stl容器中共享指针常量
- 空指针常量转换为右值
- 在参考 (T&) 和常量指针 (T* 常量) 之间进行选择