![](/img/trans.png)
[英]why am I getting the following errors : In constructor 'B::B(int, int)': no matching function for call to 'A::A()'
[英]error: no matching function for call to 'b::b()'
嗨,我只是开始用C ++编程,但是我有一个问题。 我尝试在其他班级中创建一个班级,但是它不起作用...能帮我吗?
这是我的主要:
#include <iostream>
#include "a.hpp"
#include "b.hpp"
using namespace std;
int main()
{
return 0;
}
这是我的第一堂课cpp:
#include <iostream>
#include "a.hpp"
using namespace std;
a::a(){} /* The problem is here :error: no matching function for call
to 'b::b()*/
a::~a(){}
void a::write()
{
cout << "Write a number : " << endl;
cin >> m_number;
}
这是hpp:
#ifndef A_HPP_INCLUDED
#define A_HPP_INCLUDED
#include "b.hpp"
class a : public b
{
public:
a();
~a();
void write();
protected:
int m_number;
};
#endif // INTERFACE_HPP_INCLUDED
B类cpp:
#include <iostream>
#include "b.hpp"
using namespace std;
b::b(double c, double d){m_c = c; m_d = d}
b::~b(){}
void b::write1()
{
cout << m_c+m_d<< endl;
}
和hpp:
#ifndef B_HPP_INCLUDED
#define B_HPP_INCLUDED
class b
{
public:
b(double c, double d);
~b();
void writed1();
protected:
double m_c;
double m_d;
};
#endif // B_HPP_INCLUDED
非常感谢你的帮助 !!!
类b
的唯一构造函数采用两个double
参数。
类a
是从b
派生的,但是类a
无法使用其两个必需参数来调用其超类的构造函数,并且其超类b
没有默认的构造函数。
如果您的类的构造函数具有必需的参数,并且该类没有默认的构造函数,并且您从该类派生,则派生的类负责构造其超类,并使用必需的参数来调用其构造函数。
当您定义没有构造函数的类时,C ++会为您生成一个默认构造函数。 例如,如果我们编写一个“简单的旧结构”:
struct b {
int x;
};
那么实际上就好像我们有一个默认的构造函数b()
,它什么也不做。 这使我们可以编写:
b bvar;
但是,当我们引入构造函数时,将禁止编译器生成的默认构造函数:
class b {
public:
b(int i, double d);
};
该类只有一个构造函数: b(int, double)
。 如果不调用此构造函数并将其传递两个参数,则无法构造对象:
b bvar; // error: no b::b() function.
即使我们从此类继承来创建一个具有默认构造函数的派生类a
,也是如此:
class a : public b {
public:
a();
};
a::a()
{
}
因为我们没有在a::a()
构造函数中显式初始化基b
,所以C ++编译器希望使用默认构造来创建对象的b
部分。 但是,可惜, b
没有默认构造函数!
有两种方法。 一是明确语法加入到a
构造函数初始化b
的部分a
,是这样的:
a() : b(0, 3.5)
{
}
此C ++特殊的base / member初始化语法,可在构造函数中使用以指定如何初始化成员和基础对象。 通过这种方式,您可以将所需的构造函数参数传递给他们。
第二种解决方案是在b
添加默认构造函数,或者修改其现有的构造函数,使其可以充当默认构造函数。 让我们采用第二种方法:
class b {
public:
b(int i = 0, double d = 0.0);
};
我们要做的是为两个参数都赋予默认值,使其成为可选值。 由于现在可以将b(int, double)
构造函数称为不带参数的b()
,因此可以满足默认构造函数的需要。
顺便说一下,可以为基和成员指定多个初始化器。 初始化按照定义它们的顺序进行,而不是按照初始化程序的写入顺序进行:
class foo : public bar {
xyzzy xy;
int count;
public:
foo(const string &arg)
: bar(arg) // let's assume the base constructor takes a string
, xy(42, 9) // class xyzzy has a constructor that takes a pair of integers
, count(0) // member, initialized to zero.
{
}
}
这也说明了在程序文本中布置这些初始化器的一种不错的方法,冒号和逗号在左边,就像它们是前缀一样。
只要有可能,就应该以这种方式初始化成员,而不是让它们进行默认初始化,并用构造函数主体中的赋值覆盖成员。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.