0

copyconstructor我在为我的doublependulum班级创建一个问题时遇到了问题。我在我的doubelpendulum.h文件中创建了一个,但它似乎无法在doublependulum.cpp. 我不断收到此错误:

错误 C2512:“Pendulum”:没有合适的默认构造函数可用

我不明白为什么我必须添加适当的构造函数,或者为什么我定义的构造函数(规则 103-104)不正确。如果是这样,谁能告诉我为什么它是必要的或我的有什么问题?

钟摆.h

#include<string>
using std::string;
#ifndef pendulum_H
#define pendulum_H

class Pendulum
{
public:
    Pendulum(const double,const double,double,double);
    //check function
    const double check(const double, const string) const;  //used for (L,M)
    // getfuncties
    double getL() const;
    double getM() const;
    double getTheta();
    double getOmega();
    //overload operator
    Pendulum operator+ (Pendulum);
    Pendulum operator*(const double a);
    Pendulum operator=(Pendulum);
    //copy constructor
    Pendulum(const Pendulum&  );
private:
    double L_,M_,Theta_,Omega_;
};
#endif

钟摆.cpp

#include "pendulum.h"
#include <iostream>
#include <string>
using namespace::std;
//constructor
Pendulum::Pendulum(const double L, const double M, double Theta, double Omega)
         :L_(check(L,"L")),M_(check(M,"M"))
{}
//check functie
const double Pendulum::check(const double d, const string str) const
{
    if (d<0.)
    {
        cout << "ERROR: " << str << " (" << d << ") has to be positive"  << endl;
        exit(EXIT_FAILURE);
    }
    return d;
}
//getfuncties
double Pendulum::getM() const
{
    return M_;
}
double Pendulum::getL() const
{
    return L_;
}
double Pendulum::getTheta() 
{
    return Theta_;
}
double Pendulum::getOmega() 
{
    return Omega_;
}
//overloading operators
 Pendulum Pendulum::operator+ (Pendulum param)
{
return Pendulum(L_, M_, Theta_+param.Theta_, Omega_+param.Omega_);
}

Pendulum Pendulum::  operator* (const double param)
{
return Pendulum(L_, M_, param*Theta_, param*Omega_);
}

Pendulum Pendulum::operator=(Pendulum param)
{
return Pendulum(L_, M_, param.Theta_, param.Omega_);
}
//copy constructor
Pendulum::Pendulum(const Pendulum& Object)
{
*this=Object;
}

双摆

#ifndef doublependulum_H
#define doublependulum_H
#include "pendulum.h"

class DoublePendulum
{
public:
    //constructor
    DoublePendulum(Pendulum ,Pendulum );    
    //getfuncties
    Pendulum getUp();
    Pendulum getDown();
    //Overload operators
    DoublePendulum operator+ (DoublePendulum);
    DoublePendulum operator*(const double a);
    DoublePendulum &operator=(const DoublePendulum &);
    //copy constructor
    DoublePendulum(const DoublePendulum& );
private:
    Pendulum PendUp;
    Pendulum PendDown;  
};
#endif

双摆

#include "doublependulum.h"

//constructor
DoublePendulum::DoublePendulum(Pendulum Up,Pendulum Down)
               :PendUp(Up),PendDown(Down)
{}
//getfunctions
Pendulum DoublePendulum::getUp()
{
return PendUp;
}
Pendulum DoublePendulum::getDown()
{
return PendDown;
}
//Overload operators
DoublePendulum DoublePendulum::operator+ (DoublePendulum param)
{
return DoublePendulum(PendUp + param.PendUp,PendDown + param.PendDown);
}

DoublePendulum DoublePendulum::operator* (const double param)
{
return DoublePendulum(PendUp*param,PendDown*param);
}

DoublePendulum& DoublePendulum::operator= (const DoublePendulum& param)
{
return *this; // assign to members of this object
}
//Copy constructor
DoublePendulum::DoublePendulum(const DoublePendulum& Object)
{
*this=Object;
}

主文件

#include "pendulum.h"
#include "doublependulum.h"
int main()
{return 0;}

一切都会编译,直到我添加规则:143-147 我收到此错误:

error C2512: 'Pendulum' : no appropriate default constructor available

error C2512: 'Pendulum' : no appropriate default constructor available

和一个令人担忧的警告

生成代码... c:\users\niels\documents\visual studio 2010\projects\examenopdracht\examenopdracht\pendulum.cpp(55): 警告 C4717: 'Pendulum::Pendulum' : 在所有控制路径上递归,函数会导致运行时堆栈溢出

我一直在寻找几个小时,希望有人能向我解释我的构造函数出了什么问题。

4

4 回答 4

3

您定义了一个构造函数 Pendulum::Pendulum(const double,const double,double,double) 所以编译器不会定义默认构造函数。

于 2012-05-08T17:19:47.863 回答
3

第一个问题是你试图在你的类中默认构造成员和PendUp类型PendDown,而你的类没有默认构造函数。您可以默认构造一个没有默认构造函数的类。要么为类提供默认构造函数,要么停止尝试在. 哪个是正确的解决方案取决于您的意图。只有你知道你的意图是什么。PendulumDoublePendulumPendulumPendulumDoublePendulum

正如在其他答案中所指出的那样,您的类Pendulum没有默认构造函数的原因是,在 C++ 中,一旦您为该类提供任何用户定义的构造函数,编译器就会立即停止为该类提供隐式默认构造函数。在您的情况下,您在 class 中显式声明了两个构造函数Pendulum,这会自动禁用其默认构造函数。要重新启用它,您必须明确声明它。


第二个问题根源于类中的复制构造函数和复制赋值运算符的设计Pendulum。您将复制构造函数实现为对复制赋值运算符的简单调用。但是,您的复制赋值运算符按 value接受其参数。这意味着为了准备参数,必须通过调用复制构造函数来复制构造实际参数。这是你的无限递归。即,为了完成复制构造函数,您必须调用复制分配,但是为了调用复制分配,您必须调用复制构造函数。

首先,您为什么在课堂上进行复制分配以按值Pendulum接受其论点?事实上,复制赋值运算符的当前实现似乎根本没有任何意义:它没有将任何东西分配给它的左侧。通过 const 引用使您的复制分配接受其参数,并且无限递归问题应该消失。此外,进行复制分配以实际事物分配到其左侧(即对象)。*this

其次,通过调用复制赋值运算符来实现复制构造函数的想法被打破了。赋值期望对象处于完全构造状态,而在构造函数内部,对象尚未构造。一个更好的想法是反过来做:通过使用众所周知的复制和交换习语通过复制构造来实现复制分配。

于 2012-05-08T17:29:06.020 回答
2

这两个函数是相互递归的:

Pendulum Pendulum::operator=(Pendulum param)
{
  return Pendulum(L_, M_, param.Theta_, param.Omega_);
}
//copy constructor
Pendulum::Pendulum(const Pendulum& Object)
{
  *this=Object;
}

该行*this=Object调用operator=(Pendulum). 但是,为了创建本地变量param,调用调用了复制构造函数。然后复制构造函数 inokesoperator=等。

尝试:

Pendulum& Pendulum::operator=(const Pendulum& param)
于 2012-05-08T17:19:56.450 回答
0

赋值运算符和复制构造函数存在问题。您的班级似乎不需要这些,因此只需删除它们即可解决问题,并且似乎是最干净的解决方案。

于 2012-05-08T17:27:29.717 回答