强制编译器在C++中提供默认构造函数
Forcing the compiler to provide default constructor in C++
我编写了一个C++程序,但没有定义任何构造函数。以下是代码:
#include<iostream>
using namespace std;
class test
{
public:
void print()
{
cout<< "Inside Print"<<endl;
}
};
int main()
{
test t;
t.print();
return 0;
}
当我反汇编代码时,我没有发现任何调用默认构造函数的情况。以下是主函数的汇编代码片段:
8 main:
9 .LFB1516:
10 pushl %ebp
11 .LCFI0:
12 movl %esp, %ebp
13 .LCFI1:
14 subl $8, %esp
15 .LCFI2:
16 andl $-16, %esp
17 movl $0, %eax
18 subl %eax, %esp
19 leal -1(%ebp), %eax
20 movl %eax, (%esp)
21 call _ZN4test5printEv
22 movl $0, %eax
23 leave
24 ret
如您所见,上面的代码片段中只有一个call
指令(第 # 21 行)。它正在调用print()
函数。现在我稍微修改了我的代码并引入了一个constructor
。以下是代码:
#include<iostream>
using namespace std;
class test
{
public:
test()
{
}
void print()
{
cout<< "Inside Print"<<endl;
}
};
int main()
{
test t;
t.print();
return 0;
}
我再次反汇编代码并发现以下内容:
8 main:
9 .LFB1519:
10 pushl %ebp
11 .LCFI0:
12 movl %esp, %ebp
13 .LCFI1:
14 subl $8, %esp
15 .LCFI2:
16 andl $-16, %esp
17 movl $0, %eax
18 subl %eax, %esp
19 leal -1(%ebp), %eax
20 movl %eax, (%esp)
21 call _ZN4testC1Ev
22 leal -1(%ebp), %eax
23 movl %eax, (%esp)
24 call _ZN4test5printEv
25 movl $0, %eax
26 leave
27 ret
如您所见,它调用了第 #21 行中的构造函数。现在我的问题是,如果我没有在我的代码中定义任何构造函数,编译器不是在所有情况下都提供默认构造函数吗?如果没有,那么在什么情况下,或者更确切地说,我如何强制编译器为我提供默认构造函数???
很抱歉:P冗长的问题
程序的行为符合预期。机器代码生成不是标准的一部分,您无权期望任何特定的机器代码输出 - 您只能保证输出程序按照您的要求进行操作。
为什么要强迫编译器膨胀二进制文件并减慢程序速度?
好的编译器只有在有意义的情况下才会调用默认构造函数(或任何其他函数) - 如果调用它会产生任何效果。
优化将仅从程序中排除默认构造函数(它不会执行任何操作)调用。
如果我没有在我的代码中定义任何构造函数,编译器是否在所有情况下都没有提供默认构造函数
否,仅当您未定义任何其他构造函数时。如果您的类具有任何用户声明的构造函数,则禁止默认构造函数的隐式声明。
即使你没有定义其他构造函数,除非默认构造函数实际上必须做某事,例如调用基类或成员变量的非平凡构造函数,那么它将是微不足道的,因此什么都不做,因此不需要生成代码。只有愚蠢的编译器才会生成一个完全空的函数,并坚持调用它只是为了什么都不做。
如果没有,那么在什么情况下,或者更确切地说,我如何强制编译器为我提供默认构造函数???
如果你想确保它存在,那就定义它,但如果它什么都不做,那就是浪费时间。 如果它需要执行诸如构造基类或成员变量之类的操作(并且它不会被另一个用户声明的构造函数抑制),则编译器将创建它。
编译器正在做正确的事情,你不需要强迫它做任何事情。
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 初始化具有非默认构造函数的std::数组项的更好方法
- 具有默认模板类型的默认构造函数的类型推导
- 如何使用非默认构造函数实例化模板化类
- 有没有一种代码密度较低的方法来使用非默认构造函数初始化数组?
- 声明没有默认构造函数的字段
- 没有默认构造函数作为模板参数的自定义比较器
- C++17 没有默认构造函数的地图放置(私有默认构造函数)
- 使用移动调用对等构造函数unique_ptr默认构造函数
- C++复制构造函数和默认构造函数
- 将向量从 N1 缩小到 N2 项,而不触发默认构造函数并仅使用 move 语义
- 为什么即使我调用参数化构造函数也会调用默认构造函数?
- 具有非默认构造函数的单例类
- 在 C++ 中声明 const 对象需要用户定义的默认构造函数.如果我有一个可变成员变量,为什么不呢?
- 如何处理没有默认构造函数但在另一个构造函数中构造的对象?
- 在C++中使用默认构造函数初始化对象的不同方法
- 在没有默认构造函数的情况下创建的派生对象
- 强制使用默认构造函数对成员进行未初始化的声明
- 使用默认构造函数初始化对象的不同方法
- 创建类类型的动态分配数组,其中类不得具有默认构造函数