Hi zusammen,
ich habe folgendes Problem: Ich habe folgende Template-Klasse implementiert:
template<class T, int i>class Array
{
T m_set;
int m_size;
public:
Array():m_size(i){};
void SetAt(T value, int index){ m_set[index] = value; }
T GetAt(int index){ return m_set[index]; }
int GetSize(){ return ( sizeof(m_set) / sizeof(T) ); }
void Sort(){ qsort( (void *)m_set, GetSize(), sizeof(T), compare ); }
};
das ganze wird dann folgendermaßen instanziiert, gefüllt, sortiert und ausgegeben:
int compare( const void *arg1, const void *arg2 );
int main()
{
Array< double, 5> DoubleArray;
Array< int, 5> IntArray;
int nSize = DoubleArray.GetSize();
for( int k = 0; k < nSize; k++ )
{
DoubleArray.SetAt( (double)rand(), k );
IntArray.SetAt( rand(), k );
}
DoubleArray.Sort();
IntArray.Sort();
for( int m = 0; m < nSize; m++ )
{
printf( "Wert an Index %d : %f\n", m, DoubleArray.GetAt(m) );
printf( "Wert an Index %d : %d\n", m, IntArray.GetAt(m) );
}
return 0;
}
nun zu meinem Problem. Ich habe bis jetzt folgend zwei Versionen der Funktion 'compare':
int compare( const void *arg1, const void *arg2 )
{
int result = 0;
if( * ( int* ) arg1 < * ( int* ) arg2 )
result = -1;
if( * ( int* ) arg1 > * ( int* ) arg2 )
result = 1;
return result;
}
int compare( const void *arg1, const void *arg2 )
{
int result = 0;
if( * ( double* ) arg1 < * ( double* ) arg2 )
result = -1;
if( * ( double* ) arg1 > * ( double* ) arg2 )
result = 1;
return result;
}
(wobei nur eine implementiert ist, die andere ist auskommentiert, klar warum). So nun würde ich gerne eine TemplateFunktion schreiben, welche die übergebenen Parameter entsprechend umwandelt. Im Klartext eine Funktion 'compare', welche ja nach Bedarf die Argumente 'arg1' und 'arg2' in entweder eien int oder einen double castet. Wäre nett wenn mir jemand einen kleinen Stoss in die richtige Richtung geben könnte.
Danke im vorraus