Ich erstelle eine Vorlage-Klasse, die einen Vektor von numerischen Daten enthält (kann Int, Float, Double, etc) sein. Und es hat eine Operation, die std::abs()
auf den Daten aufruft. So etwas wie der folgende Code.Template-Funktion mit Vorlage Argumente oder Typname
#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;
}
Dies funktioniert korrekt für Typen wie Int, Float, Double. Ich möchte auch diese Klasse für Typen wie std::complex<double>
verwenden können.
Umsah Ich fand, dass ich Argumente Vorlage Vorlage verwenden:
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;
}
Der vorherige Code nicht als meine Template-Klasse arbeiten erwartet zwei Argumente,
error: wrong number of template arguments (1, should be 2)
MyData<U> abs() const;
^
Idealerweise würde ich gerne etwas wie der vorherige Code In dem die my_abs()
Funktion den Typ des Vorlagearguments zurückgibt, das an meine Vorlage übergeben wird. Z. B, wenn ich ein std::complex<double>
dann meine Hauptfunktion etwas aussehen könnte:
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;
}
Ich bin nicht sicher, wie dies erreicht werden kann (oder wenn es sogar möglich, mit der gleichen Template-Klasse ist).
einfach Ihre erste Version für eine Art spezialisiert wie 'std :: Komplex' vielleicht. –