Plantilla de aprendizaje simple de C ++

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 ++

Supongo que te gusta

Origin blog.csdn.net/Fighting_gua_biu/article/details/113535334
Recomendado
Clasificación