gpt4 book ai didi

c++ - Template Specialization pointer to pointer and array passing template deduction

转载 作者:行者123 更新时间:2023-11-30 04:14:42 26 4
gpt4 key购买 nike

我编写了以下代码来测试模板特化。有没有办法让指针衰减到类型,以便我可以使用模板参数推导来获取我的 M 和 N,这样我就可以获得二维数组的行和列?我知道我可以为二维数组 vector 的 vector ,但这是模板特化的练习。下面的代码按原样工作,但是看看你是否取消注释下面的代码并注释掉当前的 T** 构造函数它不起作用。因此,构造函数当前对用于删除 data_ 成员的行数进行硬编码,这并不理想,理想情况下我会从模板推导中获取此参数。我想知道是否有一种方法可以在下面显示的代码中完成这项工作。

        //doesn't like this constructor
// template <unsigned int M, unsigned int N>
// Data ( T (&d)[M][N] ): data_(d), rows_(M), cols_(N) {};

#include <iostream>

template <typename T>
class Data
{
public:
Data ( const T& d ): data_(d) {};
Data ( T&& d ): data_(std::move(d)) {};

std::string getType() { return "Plain Data Type"; }

private:
T data_;
};


template <typename T>
class Data<T**>
{
public:

//doesn't like this constructor
// template <unsigned int M, unsigned int N>
// Data ( T (&d)[M][N] ): data_(d), rows_(M), cols_(N) {};
Data ( T** d ): data_(d), rows_(25) {};
~Data() {

for ( unsigned int i = 0; i < rows_; ++i)
{
delete [] data_[i];
}
delete [] data_;
}

std::string getType() { return "Pointer to Pointer Data Type"; }

private:
T** data_;
unsigned int rows_;
unsigned int cols_;
};


template <typename T>
class Data<T*>
{
public:
Data ( T* d ): data_(d) {};
~Data() { delete data_; }

std::string getType() { return "Pointer Data Type"; }

private:
T* data_;
};


int main ( int argc, char *argv[])
{
float f(9.65);
Data<int> d1(f);
std::cout << d1.getType() << std::endl;

int *i = new int(5);
Data<int*> d2(i);
std::cout << d2.getType() << std::endl;

int **j = new int*[25];
for ( int i = 0 ; i < 25; ++i)
j[i] = new int[50];

Data<int**> d3(j);
std::cout << d3.getType() << std::endl;
}


output:
Plain Data Type
Pointer Data Type
Pointer to Pointer Data Type

最佳答案

T**T[n][m] 不等价(我诅咒那些拒绝教授这个的大学教授)。一个是指向指针的指针,另一个是大小为 nT[m] 数组。

您可以像这样专门化您的二维数组类型:

template<typename T, size_t N, size_t M>
class Data<T[N][M]>
{
public:
Data(const T(&ar)[N][M])
{
for (size_t i=0;i<N;++i)
std::copy(std::begin(ar[i]), std::end(ar[i]), std::begin(data[i]));
}

std::string getType() { return "2D-Fixed Array Data Type"; }

private:
T data[N][M];
};

一种使用方法是这样的:

float fdat[10][20];
Data<decltype(fdat)> d4(fdat);
std::cout << d4.getType() << std::endl;

输出

二维固定数组数据类型

关于c++ - Template Specialization pointer to pointer and array passing template deduction,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18755559/

26 4 0