zhangjunxian 发表于 2021-9-8 15:22:23

关于c++ class templete的问题

本帖最后由 zhangjunxian 于 2021-9-8 15:24 编辑

今天看书看到了 关于 class templete 的内容,然后有习题 然后 我在做习题的时候出现了以下问题
1、Matrix 中 友元函数 的使用 在 vscode 里面 会报警告 这个 friend declaration 'Matrix<element>& operator*(Matrix<element>&, Matrix<element>&)' declares a non-template function [-Wnon-template-friend]
2、当 无参数的Matrix 的构造函数 中 row 和 column 的值 为 10的时候 执行程序 会自动终止程序 ,但是调试的时候又没有,能执行完毕。还有值如果小一点 比如 都是 5 5的时候程序不会出错。
3、为什么传入参数的时候不能直接传入 数组 就是 以 {1,2,3,4,5} 这样的形式传入会说没有 相应的构造函数
#include <iostream>

using namespace std;

template <typename element>
class Matrix{
    friend Matrix<element>& operator * (Matrix<element> &x1,Matrix<element> &x2);//就是这两条都会报警告
    friend Matrix<element>& operator + (Matrix<element> &x1,Matrix<element> &x2);
    private:
      int row;
      int column;
      element **arr;
    public:
      Matrix(){
            row = 10; column = 10;             //这个都为10的时候执行程序会出错 自动终止退出
            arr = new element* ;
            for(int i=0;i<row;i++){
                arr = new element(column);
                for(int j=0;j<column;j++){
                  if(i==j) arr = 1;
                  else arr = 0;
                }
            }
      }
      Matrix(element a[],int r, int c){
            row = r;
            column = c;
            arr = new element* ;
            int cout = 0;
            for(int i=0;i<row;i++){
                arr = new element(column);
                for(int j=0;j<row;j++){
                   arr = a;
                   cout++;
                }
            }
      }
      ~Matrix(){for(int i = 0;i<row;i++){
            delete [] arr;
      }}
      int &operator() (int row ,int column) {return arr;};
      int &operator() (int row, int column) const {return arr;};
      void print(){
            for(int i=0;i<row;i++){
                cout << "[ ";
                for(int j=0;j<column;j++){
                  cout << arr << " ";
                }
                cout <<"]"<<endl;
            }
            cout << endl;
      };
};

template <typename element>
Matrix<element>& operator * (Matrix<element> &x1,Matrix<element> &x2){
    Matrix<element>* result = new Matrix<element>();
    for(int i=0;i<4;i++){
      int r = 0;
      for(int j=0;j<4;j++){
            for(int k=0;k<4;k++){
                r += x1(k,j)*x2(i,k);
            }
            result->arr = r;
      }
    }
    return *result;
}

template <typename element>
Matrix<element>& operator + (Matrix<element> &x1,Matrix<element> &x2){
    Matrix<element>* result = new Matrix<element>();
    for(int i=0;i<4;i++){
      for(int j=0;j<4;j++){
            result->arr = x1(i,j)+x2(i,j);
      }
    }
    return *result;
}

int main(){
    Matrix<float> x = Matrix<float>();
    x.print();
    float w[] = {1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4};
    //Matrix<float> y = Matrix<float>({1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4},4,4);//就是这个 不能以这个形式传入
    Matrix<float> y = Matrix<float>(w,4,4);
    y.print();

}

人造人 发表于 2021-9-8 17:57:41

#include <iostream>

using namespace std;

template <typename element> class Matrix {
    template <typename _element>
    friend Matrix<_element> &operator*(Matrix<_element> &x1,
            Matrix<_element> &x2); //就是这两条都会报警告
    template <typename _element>
    friend Matrix<_element> &operator+(Matrix<_element> &x1, Matrix<_element> &x2);

private:
    int row;
    int column;
    element **arr;

public:
    Matrix() {
      row = 10;
      column = 10; //这个都为10的时候执行程序会出错 自动终止退出
      arr = new element *;
      for(int i = 0; i < row; i++) {
            //arr = new element(column);
            arr = new element;
            for(int j = 0; j < column; j++) {
                if(i == j)
                  arr = 1;
                else
                  arr = 0;
            }
      }
    }
    Matrix(const std::initializer_list<element> &rhs, int r, int c) {
      row = r; column = c;
      arr = new element *;
      for(int i = 0; i < row; ++i) {
            arr = new element;
            for(int j = 0; j < column; ++j) {
                //arr = rhs;      // 奇怪,std::initializer_list 没有 operator[]
                arr = *(rhs.begin() + (i * column + j));
            }
      }
    }
    Matrix(element a[], int r, int c) {
      row = r;
      column = c;
      arr = new element *;
      int cout = 0;
      for(int i = 0; i < row; i++) {
            //arr = new element(column);
            arr = new element;
            for(int j = 0; j < row; j++) {
                arr = a;
                cout++;
            }
      }
    }
    ~Matrix() {
      for(int i = 0; i < row; i++) {
            delete[] arr;
      }
      delete[] arr;
    }
    //int &operator()(int row, int column) { return arr; };
    int &operator()(int row, int column) const { return arr; };
    void print() {
      for(int i = 0; i < row; i++) {
            cout << "[ ";
            for(int j = 0; j < column; j++) {
                cout << arr << " ";
            }
            cout << "]" << endl;
      }
      cout << endl;
    };
};

template <typename element>
Matrix<element> &operator*(Matrix<element> &x1, Matrix<element> &x2) {
    Matrix<element> *result = new Matrix<element>();
    for(int i = 0; i < 4; i++) {
      int r = 0;
      for(int j = 0; j < 4; j++) {
            for(int k = 0; k < 4; k++) {
                r += x1(k, j) * x2(i, k);
            }
            result->arr = r;
      }
    }
    return *result;
}

template <typename element>
Matrix<element> &operator+(Matrix<element> &x1, Matrix<element> &x2) {
    Matrix<element> *result = new Matrix<element>();
    for(int i = 0; i < 4; i++) {
      for(int j = 0; j < 4; j++) {
            result->arr = x1(i, j) + x2(i, j);
      }
    }
    return *result;
}

int main() {
    Matrix<float> x = Matrix<float>();
    x.print();
    float w[] = {1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4};
   Matrix<float> z = Matrix<float>({1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4},4,4);
    // //就是这个 不能以这个形式传入
    Matrix<float> y = Matrix<float>(w, 4, 4);
    y.print();
}

zhangjunxian 发表于 2021-9-13 13:49:38

人造人 发表于 2021-9-8 17:57


谢谢大佬
页: [1]
查看完整版本: 关于c++ class templete的问题