C++编译器如何检测非常量函数体
How can a C++ compiler detect a non-const function body?
偶然发现了以下一段代码:
class Person
{
private:
char name[10];
public:
// this won't compile:
char* getName_1() const {
return name;
}
// this will:
const char* getName_2() const {
return name;
}
};
我想知道编译器如何确切地判断getName_1()
不是常量函数。因为函数体内没有一段代码实际修改成员变量。
由于getName_1
被标记为const
因此此类的所有字段都被视为常量。
所以getName_1
name
的类型是const char[10]
.
这不能隐式转换为char *
(返回类型(,因此编译器报告错误。
getName_1()
是一个常量方法,因为它在其声明中被标记为const
。这意味着它的隐式this
指针是const
的,所以name
成员被视为const
,所以getName_1()
不能返回一个指向常量数据的非常量指针,这就是为什么它不会编译。
作为其他(正确(答案的补充,它编译:
class Person
{
private:
char* name;
public:
// this compiles:
char* getName_1() const {
return name;
}
};
最重要的是,这表明与流行的神话相反,C++中的数组不是一个指针。
相关文章:
- #定义c-预处理器常量..我做错了什么
- 用C++中的一个变量定义一个常量
- 什么时候在C++中返回常量引用是个好主意
- 代理对象的常量正确性
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 通过多个头文件使用常量变量
- 在cuda线程之间共享大量常量数据
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 是默认情况下分配给char数组常量的值
- 私有类型的静态常量成员
- OpenGL大的3D纹理(>2GB)非常慢
- 类似枚举的计算常量
- 递归模板化函数不能分配给具有常量限定类型"const tt &"的变量"state"
- 使用常量键但非常量值进行映射
- 为什么`is_open()`非常常量
- 从getter方法返回常量和非常量值
- 阻止const类函数在引用成员上调用非常常量类函数
- C++初始化非常大的常量数组,最佳实践
- 提高c++中非常大的常量的可读性