C++11 在C++中没有匹配的操作符+,也没有匹配矢量构造调用

C++11 在C++中没有匹配的操作符+,也没有匹配矢量构造调用,c++11,templates,operator-overloading,overloading,expression-templates,C++11,Templates,Operator Overloading,Overloading,Expression Templates,我正在尝试使用表达式模板实现矩阵加法。我正面临一些麻烦。这是我的矩阵代码: #include<iostream> #include<vector> #include<cassert> template <typename T> class MatrixExpression { public: double operator[](size_t i) const { return static_cast<T const&&g

我正在尝试使用表达式模板实现矩阵加法。我正面临一些麻烦。这是我的矩阵代码:

#include<iostream>
#include<vector>
#include<cassert>

template <typename T>
class MatrixExpression {
  public:
    double operator[](size_t i) const { return static_cast<T const&>(*this)[i];}
    size_t size()const { return static_cast<T const&>(*this).size(); }
};
template<typename T>
class Matrix:public MatrixExpression<Matrix<T>>
{
    std::vector<std::vector<T>> mat;

    public:
    Matrix(std::size_t m, std::size_t n):mat(m,std::vector<T>(n)){}



    class Proxy
    {
        std::vector<T> vec;
        public:
        Proxy(std::vector<T> vec):vec(vec){ }

        T operator[](std::size_t i){ return vec[i];}
        //T &operator[](std::size_t i){ return vec[i];}
        std::size_t size() const{ return vec.size(); }
    };

    Proxy operator[](std::size_t i) const { return Proxy(mat[i]); }
    //Proxy &operator[](std::size_t i)      { return Proxy(mat[i]); }
    size_t size() const { return mat.size(); }

    Matrix(std::initializer_list<std::initializer_list<T>> lst)
    {
        int m=0,n=0;
        for(auto l:lst )
        {
            for(auto v:l)
            {
                n++;
            }
            m++;
        }
        int i=0,j=0;
        mat(m,std::vector<T>(n));
        for(auto l:lst )
        {
            for(auto v:l)
            {
                mat[i].push_back(v);
            }
            i++;
        }
    }


    Matrix(MatrixExpression<T> const& matx):mat(matx.size(),std::vector<T>(matx[0].size))
    {
        for(int i=0;i<matx.size();i++)
        {
            for(int j=0;j<matx[0].size();j++)
            {
                mat[i][j] = matx[i][j];
            }
        }
    }
};

template<typename T, typename X, typename Y>
class MatrixSum:public MatrixExpression<MatrixSum<T,X,Y>>
{
    X const& x;
    Y const& y;

    public:
    MatrixSum(X const& x1, Y const& y1):x(x1),y(y1){
        assert(x1.size()==y1.size());
        assert(x1[0].size()==y1[0].size());
    }

    class ProxySum
    {
        std::vector<T> vec1,vec2;
        public:
        ProxySum(std::vector<T> vec1,std::vector<T> vec2):vec1(vec1),vec2(vec2){ }

        T operator[](std::size_t i){ return vec1[i] + vec2[i];}
        //T &operator[](std::size_t i){ return vec1[i] + vec2[i];}
        std::size_t size() const{ return vec1[0].size(); }
    };
    ProxySum operator[](std::size_t i) const { return ProxySum(x[i],y[i]); }
    //ProxySum &operator[](std::size_t i){ return ProxySum(x[i],y[i]); }
    size_t size() const { return x.size(); } 

};

template<typename T,typename X,typename Y>
MatrixSum<T,X,Y>
operator+(X const& x, Y const& y)
{
    return MatrixSum<T,X,Y>(x,y);
}

我在使用Matrix类时遇到两个错误。第一个是,对于我在测试中使用int的矩阵,运算符+不存在,即使我已经为“+”实现了运算符重载,另一个错误是在矩阵的第二个构造函数中。它表示我为Mat变量的构造函数所做的调用无效。但是向量确实有这样的构造函数< /p>

1。下面的行不是一个有效的C++语法:

mat(m,std::vector<T>(n));
2对于操作员+您提供的:

template<typename T,typename X,typename Y>
MatrixSum<T,X,Y>
operator+(X const& x, Y const& y)
{
    return MatrixSum<T,X,Y>(x,y);
}
…这可能不是你想要的


正确的方法是尝试在编译时,基于X和Y类型,使用一些元编程来计算T。

你能告诉我一些方法吗。我是新的C++模板。我对此没有深入的了解。@Shantanu Shinde如果t是求和类型,您可以在矩阵中定义value_type,然后按如下方式推导求和类型:decltypestd::decval+std::decval
template<typename T,typename X,typename Y>
MatrixSum<T,X,Y>
operator+(X const& x, Y const& y)
{
    return MatrixSum<T,X,Y>(x,y);
}
matrix1.operator +<some_type>(matrix2);