Programación genérica: plantillas de funciones y plantillas de clases
Plantilla de función:
*template <typename T> //typename也可使用class
void func(T &a){
}*
Hay dos formas de utilizar las plantillas:
1. Deducción de tipo automática
func(a)
2、显式指定类型
func<int>(a)
El propósito de la plantilla es mejorar la reutilización del código y parametrizar el tipo.
Notas:
· Derivación automática de tipo, debe derivar un tipo de datos consistente T antes de que pueda usarse
· La plantilla debe determinar el tipo de datos de T antes de que pueda ser usado
La diferencia entre las funciones ordinarias y las plantillas:
la inferencia de tipo automática no tendrá conversión de tipo implícita y
el tipo explícito tendrá conversión de tipo implícita
Reglas de llamada para funciones ordinarias y funciones de plantilla
· Si se pueden implementar tanto las plantillas de función como las funciones ordinarias, las funciones ordinarias
se llamarán primero
. La plantilla de función se puede forzar a que se llame a través de la lista de parámetros de plantilla vacía . La plantilla de función también se puede sobrecargar
. Si la plantilla de función puede producir más coincidencias, llame primero a la plantilla de función
Limitaciones de las
plantillas : las plantillas no son omnipotentes, algunos tipos de datos específicos deben implementarse de formas específicas
·利用具体化的模板,可以解决自定义类型的通用化
P.ej:
//不同类型排序模板
#include <iostream>
using namespace std;
template<typename T>
void mySwap(T &a, T&b)
{
T temp = a;
a = b;
b = temp;
}
template<class T>
void mySort(T arr[], int len)
{
for (int i = 0; i < len; i++){
int max = i;
for (int j = i + 1; j < len; j ++){
if (arr[max] < arr[j]){
max = j;
}
}
if (max != i){
mySwap(arr[max], arr[i]);
}
}
}
template<class T>
void printArray(T arr[], int len)
{
for (int i = 0; i < len; i ++)
{
cout << arr[i] << " ";
}
cout <<endl;
}
void test1()
{
char charArr[] = "fhdjkhfacb";
int num = sizeof(charArr);
mySort(charArr, num);
printArray(charArr, num);
}
void test2()
{
int intArr[] = {
4,455,345,22,4,55,6564,35,3,6757};
int num = sizeof(intArr) / sizeof(int);
mySort(intArr, num);
printArray(intArr, num);
}
int main()
{
test1();
test2();
system ("pause");
return 0;
}
* Ejercicios de aprendizaje del curso Dark Horse Programmer C ++