Error - C++:修订间差异

来自牛奶河Wiki
跳到导航 跳到搜索
无编辑摘要
第3行: 第3行:


=== 在构造函数内初始化引用成员变量 ===
=== 在构造函数内初始化引用成员变量 ===
引用成员变量必须在构造函数的初始化列表(Constructor Initialization List)中进行初始化。这是因为引用一旦被初始化,就不能改变其引用的对象。因此,它必须在声明时就被初始化。(来自[https://developer.aliyun.com/article/1467283 《C++深度解析:引用成员变量的初始化及其在模板编程中的应用(一)》])
''<small>(错误说明)引用成员变量必须在构造函数的初始化列表(Constructor Initialization List)中进行初始化。这是因为引用一旦被初始化,就不能改变其引用的对象。因此,它必须在声明时就被初始化。(来自[https://developer.aliyun.com/article/1467283 《C++深度解析:引用成员变量的初始化及其在模板编程中的应用(一)》])</small>''


根据下面两段说明,更确切的说法是:引用成员变量之所以必须在构造函数的初始化列表中进行初始化,是因为引用在声明时必须初始化为一个已存在的对象。所以,在构造函数内初始化引用成员变量,报错的是声明时未初始化(int& myRef)。
根据下面两段说明,'''确切的说法'''是:引用成员变量之所以必须在构造函数的初始化列表中进行初始化,是因为引用在声明时必须初始化为一个已存在的对象。所以,在构造函数内初始化引用成员变量,报错的是声明时未初始化(int& myRef)。
* 引用(reference)是 C++ 中的一个别名,它在声明时必须初始化为一个已存在的对象。一旦初始化,引用就和它所引用的对象绑定在一起,它们共享同一个内存地址
*引用(reference)是 C++ 中的一个别名,它在声明时必须初始化为一个已存在的对象。一旦初始化,引用就和它所引用的对象绑定在一起,它们共享同一个内存地址
* 引用本质上是一个常量指针,它只是给一个已存在的对象起了另外一个名字。这个名字一旦确定,就不能再指向其他的对象
*引用本质上是一个常量指针,它只是给一个已存在的对象起了另外一个名字。这个名字一旦确定,就不能再指向其他的对象


  <small><nowiki>class MyClass {
  <small><nowiki>class MyClass {
public:
public:
    MyClass(int& ref) {
    MyClass(int& ref) {
        myRef = ref;  // Error
        myRef = ref;  // Error
    }
    }
private:
private:
    int& myRef;
    int& myRef;
};
};
 
class MyClass {
class MyClass {
public:
public:
    MyClass(int& ref) : myRef(ref) {}  // OK
    MyClass(int& ref) : myRef(ref) {}  // OK
private:
private:
    int& myRef;
    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;
 };