术语“默认构造函数”在Java和C ++中都是官方的,在这两个世界中它似乎意义不同。我可以知道我的理解是否正确以及某些相关概念的正确命名是什么?
Java 中的默认构造函数表示当没有为类定义构造函数时由Compiler生成的(No-arg)构造函数。
C ++中的默认构造函数表示可以不带参数调用的构造函数。
给出以下示例
爪哇:
class NoCtorClass {
// No ctor defined, compiler is generating one --------- J-1
}
class NoArgCtorClass {
public NoArgCtorClass() { ... } -------------------------- J-2
}
C ++:
class NoCtorClass {
// implicitly NoCtorClass() constructor is provided -------- C-1
}
class DefaultCtorClass {
public:
// Explicitly telling compiler to give the default one
DefaultCtorClass() = default; ---------------------------- C-2
}
class NoArgCtorClass {
public:
NoArgCtorClass(); ----------------------------------------- C-3
}
NoArgCtorClass::NoArgCtorClass() {....}
class NoArgCtor2Class {
public:
NoArgCtor2Class(int i = 0); -------------------------------- C-4
}
NoArgCtor2Class::NoArgCtor2Class (int i = 0) {....}
在Java中,只有J-1被正式称为默认构造函数,而J-2则不是。
在C ++中,所有C-1到C-4都被正式称为默认构造函数。
我的理解是否正确?
如果是这样,术语中的一些问题:
对于没有参数的ctor,Java中的正确名称是什么? (即J-1和J2)。我通常称之为No-Arg Constructor。 (对应于C ++中default-ctor的概念)
编译器生成的ctor在C ++中的正确名称是什么? (即C-1和C-2。使用关键字default
,它似乎应该被称为默认值。那么它应该被称为“默认默认构造函数”吗?(对应于Java中default-ctor的概念) )
与2类似,我们应该如何调用编译器生成的Copy-ctor,赋值运算符等? “默认拷贝构造”?
答案 0 :(得分:0)
在java中,它们都被称为默认构造函数。 Java编译器在内部生成没有args的构造函数。如果你指定没有args的构造函数,就像你要覆盖构造函数一样。
public NoArgCtorClass() { ... }
例如,当您实例化对象时,您在{...}中保留的代码将被执行...
注意:如果你有一个重载的构造函数,你需要明确地编写默认的constrcutor,因为在这种情况下compilor不生成args构造函数。
答案 1 :(得分:0)
Java docs - “如果一个类不包含构造函数声明,则隐式声明一个没有形式参数且没有throws子句的默认构造函数”。如果用户定义了无参数构造函数,则根据JLS,它仍被称为默认构造函数。在实践中,程序员并不总是坚持这个约定,因为它可能是模糊的(有些不使用arg构造函数等)。
根据我的经验,构造函数的C1和C2版本(隐式和显式)都被称为默认构造函数。
编译器为类生成的默认方法通常称为以下方法;默认构造函数,复制构造函数,复制赋值和析构函数。它通常只是无参数构造函数接收前缀“default”,即使默认情况下给出了所有方法(空类)。