C++ Error:修订间差异
跳到导航
跳到搜索
无编辑摘要 |
|||
第3行: | 第3行: | ||
=== 在构造函数内初始化引用成员变量 === | === 在构造函数内初始化引用成员变量 === | ||
''<small>(错误说明)引用成员变量必须在构造函数的初始化列表(Constructor Initialization List)中进行初始化。这是因为引用一旦被初始化,就不能改变其引用的对象。因此,它必须在声明时就被初始化。(来自[https://developer.aliyun.com/article/1467283 《C++深度解析:引用成员变量的初始化及其在模板编程中的应用(一)》])</small>'' | |||
根据下面两段说明,'''确切的说法'''是:引用成员变量之所以必须在构造函数的初始化列表中进行初始化,是因为引用在声明时必须初始化为一个已存在的对象。所以,在构造函数内初始化引用成员变量,报错的是声明时未初始化(int& myRef)。 | |||
* 引用(reference)是 C++ 中的一个别名,它在声明时必须初始化为一个已存在的对象。一旦初始化,引用就和它所引用的对象绑定在一起,它们共享同一个内存地址 | *引用(reference)是 C++ 中的一个别名,它在声明时必须初始化为一个已存在的对象。一旦初始化,引用就和它所引用的对象绑定在一起,它们共享同一个内存地址 | ||
* 引用本质上是一个常量指针,它只是给一个已存在的对象起了另外一个名字。这个名字一旦确定,就不能再指向其他的对象 | *引用本质上是一个常量指针,它只是给一个已存在的对象起了另外一个名字。这个名字一旦确定,就不能再指向其他的对象 | ||
<small><nowiki>class MyClass { | <small><nowiki>class MyClass { | ||
public: | public: | ||
MyClass(int& ref) { | |||
myRef = ref; // Error | |||
} | |||
private: | private: | ||
int& myRef; | |||
}; | }; | ||
class MyClass { | class MyClass { | ||
public: | public: | ||
MyClass(int& ref) : myRef(ref) {} // OK | |||
private: | private: | ||
int& myRef; | |||
};</nowiki></small> | };</nowiki></small> | ||
[[分类:Develop]] | [[分类:Develop]] | ||
[[分类:C++]] | [[分类:C++]] |
2024年9月10日 (二) 10:11的版本
undefined reference to pthread_create
-pthread
在构造函数内初始化引用成员变量
(错误说明)引用成员变量必须在构造函数的初始化列表(Constructor Initialization List)中进行初始化。这是因为引用一旦被初始化,就不能改变其引用的对象。因此,它必须在声明时就被初始化。(来自《C++深度解析:引用成员变量的初始化及其在模板编程中的应用(一)》)
根据下面两段说明,确切的说法是:引用成员变量之所以必须在构造函数的初始化列表中进行初始化,是因为引用在声明时必须初始化为一个已存在的对象。所以,在构造函数内初始化引用成员变量,报错的是声明时未初始化(int& myRef)。
- 引用(reference)是 C++ 中的一个别名,它在声明时必须初始化为一个已存在的对象。一旦初始化,引用就和它所引用的对象绑定在一起,它们共享同一个内存地址
- 引用本质上是一个常量指针,它只是给一个已存在的对象起了另外一个名字。这个名字一旦确定,就不能再指向其他的对象
class MyClass { public: MyClass(int& ref) { myRef = ref; // Error } private: int& myRef; }; class MyClass { public: MyClass(int& ref) : myRef(ref) {} // OK private: int& myRef; };