假设我有一个基类:
class baseClass
{
public:
baseClass() { };
};
还有一个派生类:
class derClass : public baseClass
{
public:
derClass() { };
};
当我创建 derClass
的一个实例时,会调用 baseClass
的构造函数。我如何防止这种情况?
假设我有一个基类:
class baseClass
{
public:
baseClass() { };
};
还有一个派生类:
class derClass : public baseClass
{
public:
derClass() { };
};
当我创建 derClass
的一个实例时,会调用 baseClass
的构造函数。我如何防止这种情况?
struct noprapere_tag {};
class baseClass
{
public:
baseClass() : x (5), y(6) { };
baseClass(noprapere_tag()) { }; // nothing to do
protected:
int x;
int y;
};
class derClass : public baseClass
{
public:
derClass() : baseClass (noprapere_tag) { };
};
derClass() : baseClass (noprapere_tag) { }; 在这行代码中,noprapere_tag不是一个对象,你应该创建一个对象吗?- Abhishek Agarwal
样例工作程序
#include <iostream>
using namespace std;
class A
{
public:
A()
{
cout<<"a\n";
}
A(int a)
{}
};
class B:public A
{
public:
B() : A(10)
{
cout<<"b\n";
}
};
int main()
{
new A;
cout<<"----------\n";
new B;
return 0;
}
输出
a
----------
b
class Base {
protected:
Base() {}
public:
int a;
Base(int x) {a = 12;}
};
class Derived : Base {
public:
Derived(int x) {a = 42;}
};
这将阻止任何外部代码使用默认的 Base
构造函数(因此无法正确初始化 a
)。您只需要确保在 Derived
构造函数中初始化所有的 Base
字段即可。