c – 类定义中的引用变量

我正在学习C,我读到所有引用必须在声明时初始化,
并且不会有“未初始化的引用”.但是如果引用变量是一个类成员呢?
class test
{
    int &k;
};

int main()
{
    test *abc = new test;
}

该程序编译并正常运行(g,无警告).但是,abc-> k是一个引用,但是它被初始化为什么?或者,这是某种“未初始化的参考”,还是其他的?

解决方法

该程序是不正确的,因为它构造一个类不能初始化引用类型的非静态成员实体.

我相信gcc不能编译这个,但是我只收到在类中没有构造函数的“非静态引用”int& test :: k’的警告.

test是一个非POD-struct类型,因为它包含一个引用成员. (9 [class] / 4)

new test default – 初始化动态分配的类. (5.3.4 [expr.new] / 15)

默认初始化类型test的对象意味着调用隐式声明和隐式定义的默认构造函数. (8.5 [dcl.init] / 5)

隐式定义的默认构造函数等同于具有空mem-initialized-list和空函数体的默认构造函数. (12.1 [class.ctor] / 7)

更多:

The implicitly-defined default constructor performs the set of initializations of the
class that would be performed by a user-written default constructor for that class with an empty mem-initializer-list (12.6.2) and an empty function body. If that user-written default constructor would be ill-formed,the program is ill-formed.

如果实体在mem-initializer-list中不是名称,并且成员不是类型[具有进一步限制],则实体未初始化.

Otherwise,the entity is not initialized. If the entity is of const-qualified type,or reference type,[or …] the program is ill-formed.” (12.6.2 [class.base.init] / 4)

相关文章

/** C+⬑ * 默认成员函数 原来C++类中,有6个默认成员函数: 构造函数 析构函数 拷贝...
#pragma once // 1. 设计一个不能被拷贝的类/* 解析:拷贝只会放生在两个场景中:拷贝构造函数以及赋值运...
C类型转换 C语言:显式和隐式类型转换 隐式类型转化:编译器在编译阶段自动进行,能转就转,不能转就编译...
//异常的概念/*抛出异常后必须要捕获,否则终止程序(到最外层后会交给main管理,main的行为就是终止) try...
#pragma once /*Smart pointer 智能指针;灵巧指针 智能指针三大件//1.RAII//2.像指针一样使用//3.拷贝问...
目录<future>future模板类成员函数:promise类promise的使用例程:packaged_task模板类例程...