Quando provo a utilizzare float
come parametro del modello, il compilatore richiede questo codice, mentre int
funziona bene.
È perché non posso utilizzare float
come parametro del modello?
#include<iostream>
using namespace std;
template <class T, T defaultValue>
class GenericClass
{
private:
T value;
public:
GenericClass()
{
value = defaultValue;
}
T returnVal()
{
return value;
}
};
int main()
{
GenericClass <int, 10> gcInteger;
GenericClass < float, 4.6f> gcFlaot;
cout << "\n sum of integer is "<<gcInteger.returnVal();
cout << "\n sum of float is "<<gcFlaot.returnVal();
return 0;
}
Errore:
main.cpp: In function `int main()':
main.cpp:25: error: `float' is not a valid type for a template constant parameter
main.cpp:25: error: invalid type in declaration before ';' token
main.cpp:28: error: request for member `returnVal' in `gcFlaot',
which is of non-class type `int'
Sto leggendo "Strutture dati per programmatori di giochi" di Ron Penton, l'autore passa un float
, ma quando lo provo non sembra compilare.
float
come parametro di modello non di tipo ? In che capitolo si tratta?