我正在尝试使用+添加2个向量(数学向量)。这是我的代码:

class Vector{
    double v[Max_size];
    int dim;
public:
    int getDim() const;
    Vector();
    Vector(int n);
    Vector(const Vector& a);
    Vector add(const Vector&b);
    friend Vector operator+(Vector summand1, Vector summand2);
};


运算符重载:

Vector operator+(Vector summand1, Vector summand2){
    int dim1 = summand1.getDim();
    int dim2 = summand2.getDim();
    assert(dim1 == dim2);
    Vector sum(dim1);
    int i;
    for(i = 0; i < dim1; i++){
        sum.v[i] = summand1.v[i] + summand2.v[i];
    }
    return sum;
}


以及我如何使用它:

Vector m = v+t;


当我运行代码时,它总是显示m为(0,0)(2D向量),这是构造函数生成的默认值。它出什么问题了?谢谢!

最佳答案

您的副本构造函数:

Vector::Vector(const Vector& a){
    dim = a.dim;
    Vector(dim);
}


正确设置dim成员的值,但没有其他副作用。

您应该具有以下代码的变体:

Vector::Vector(const Vector& a) : dim(a.dim) {
    std::copy(std::begin(a.v), std::end(a.v), v);
}


这实际上将复制参数中存在的数据,并且您将看到代码的正确行为:

// Copy constructor called here, but did not correctly copy the data before.
Vector m = v + t;




为了获得更好的(我想让它更简单,更安全)Vector类,如果您可以访问至少与C ++ 11兼容的编译器,则可以编写:

class Vector{
    std::array<double, Max_size> v; // Note the std::array here.
    int dim;
public:
    int getDim() const;
    Vector();
    Vector(int n);
    Vector(const Vector& a);
    Vector add(const Vector&b);
    friend Vector operator+(Vector summand1, Vector summand2);
};


std::array会处理所有事情,只要您像这样编写副本构造函数即可:

Vector::Vector(const Vector& a) : v(a.v), dim(a.dim) {

}


或者,甚至更好的是,您可以让编译器本身以相同的行为生成副本构造函数。

10-08 20:00