为什么常量方法可以采用非常量引用?
Why can a const method take a non const reference?
我知道 const 方法无法修改调用它的对象。看看这个代码:
class A{
int a;
public:
void f(A & a_) const {
a_.a=5;
};
};
int main(){
A x;
x.f(x);
return 0;
}
为什么要编译此代码?为什么在将方法声明为常量时,我甚至可以分配对同一类的非 const 对象的引用?通常,编译器如何检查函数可以修改对象的所有可能情况?
我知道 const 方法无法修改调用它的对象。
这是一种过于简化,而且有点不准确。
const
函数仅表示隐式this
指针是指向const
的指针。
为什么要编译此代码?
因为它的格式很好。
为什么在将方法声明为常量时,我甚至可以分配对同一类的非 const 对象的引用?
因为函数的恒定性不会影响可以通过引用修改的对象。
通常,编译器如何检查函数可以修改对象的所有可能情况?
编译器根本不进行此类检查。
const
成员函数不能使用"隐式"this
参数修改从中调用它的对象。f(...)
(忽略成员可见性(等同于 free 函数
void f(const A* this, A& _a) {
_a.a = 5;
}
如果将同一对象作为非常量指针或引用传递,则仍允许对其进行修改。
相关文章:
- #定义c-预处理器常量..我做错了什么
- 用C++中的一个变量定义一个常量
- 什么时候在C++中返回常量引用是个好主意
- 代理对象的常量正确性
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 通过多个头文件使用常量变量
- 在cuda线程之间共享大量常量数据
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 是默认情况下分配给char数组常量的值
- 私有类型的静态常量成员
- OpenGL大的3D纹理(>2GB)非常慢
- 类似枚举的计算常量
- 递归模板化函数不能分配给具有常量限定类型"const tt &"的变量"state"
- 使用常量键但非常量值进行映射
- 为什么`is_open()`非常常量
- 从getter方法返回常量和非常量值
- 阻止const类函数在引用成员上调用非常常量类函数
- C++初始化非常大的常量数组,最佳实践
- 提高c++中非常大的常量的可读性