Я создаю класс шаблона, который содержит вектор числовых данных (может быть int, float, double и т. Д.). И он имеет одну операцию, которая называет std::abs()
. Что-то вроде следующего кода.Шаблон функции с аргументами шаблона или typename
#include <iostream>
#include <complex>
#include <vector>
template<typename T> class MyData
{
public:
std::vector<T> data;
MyData<T> my_abs() const;
};
template<typename T>
MyData<T> MyData<T>::my_abs() const
{
MyData<T> output;
output.data.reserve(data.size());
typename std::vector<T>::const_iterator it;
for (it = data.begin(); it != data.end(); it++)
{
output.data.push_back(std::abs(*it));
}
return output;
}
int main()
{
MyData<double> A;
A.data = std::vector<double>(10, -1.0);
MyData<double> test = A.my_abs();
for (auto el : test.data)
{
std::cout << el << std::endl;
}
return 0;
}
Это правильно работает для таких типов, как int, float, double. Я также хочу использовать этот класс для таких типов, как std::complex<double>
.
Оглядевшись, я обнаружил, что я мог бы использовать аргументы шаблона Шаблон:
template<template<typename> class T, typename U> class MyData
{
public:
std::vector<T<U>> data;
MyData<U> my_abs() const;
};
template<template<typename> class T, typename U>
MyData<U> MyData<T<U>>::my_abs() const
{
MyData<U> output;
output.data.reserve(data.size());
typename std::vector<T<U>>::const_iterator it;
for (it = data.begin(); it != data.end(); it++)
{
output.data.push_back(std::abs(*it));
}
return output;
}
предыдущий код не работает, как мой шаблон класса ожидает два аргумента,
error: wrong number of template arguments (1, should be 2)
MyData<U> abs() const;
^
В идеале я хотел бы что-то вроде предыдущий код. В которой функция my_abs()
возвращает тип аргумента шаблона, переданный моему шаблону. Например, если я использую std::complex<double>
тогда моя главная функция может выглядеть примерно так:
int main()
{
MyData<std::complex<double>> A;
A.data = std::vector<std::complex<double>>(10, std::complex<double>(-1.0, -1.0));
MyData<double> test = A.my_abs();
for (auto el : test.data)
{
std::cout << el << std::endl;
}
return 0;
}
Я не знаю, как это может быть достигнуто (или, если это вообще возможно, используя один и тот же класс шаблона).
Просто специализироваться на 1-ый вариант для типа, как 'станд :: комплекса' возможно. –