Шаблоны функций

Шаблоны вводятся для того, чтобы автоматизировать создание функций, обрабатывающих разнотипные данные. Например, алгоритм сортировки можно использовать для массивов различных типов. При перегрузке функции для каждого используемого типа определяется своя функция. Шаблон функции определяется один раз, но определение параметризируется, т. е. тип данных передается как параметр шаблона. Формат шаблона:

template <class имя_типа [,class имя_типа]>

заголовок_функции

{тело функции}

Таким образом, шаблон семейства функций состоит из 2 частей – заголовка шаблона: template<список параметров шаблона> и обыкновенного определения функции, в котором вместо типа возвращаемого значения и/или типа параметров, записывается имя типа, определенное в заголовке шаблона.

Пример 1.

//шаблон функции, которая находит абсолютное значение числа любого типа

template<class type>//type – имя параметризируемого типа

type abs(type x)

{

if(x<0)return -x;

else return x;

}

Шаблон служит для автоматического формирования конкретных описаний функций по тем вызовам, которые компилятор обнаруживает в программе. Например, если в программе вызов функции осуществляется как abs(-1.5), то компилятор сформирует определение функции double abs(double x){. . . }.

 

Пример 2.

//шаблон функции, которая меняет местами две переменных

template <class T>//T – имя параметризируемого типа

void change(T*x,T*y)

{T z=*x;*x=*y;*y=z;}

Вызов этой функции может быть :

long k=10,l=5;

change(&k,&l);

Компилятор сформирует определение:

void change(long*x,long*y){ long z=*x;*x=*y;*y=z;}

 

Пример 3.

#include<iostream.h>

template<class Data>

Data&rmax(int n,Data a[])

{

int im=0;

for(int i=0;i<n;i++)

if(a[im]<a[im])im=i;

return d[im];//возвращает ссылку на максимальный элемент в массиве

}

void main()

{int n=5;

int x[]={10,20,30,15};

cout<<” rmax(n,x)=”<<rmax(n,x)<<” ”;

rmax(n,x)=0;

for(int i=0;i<n;i++)

cout<<x[i]<<” “;

cout<<” ”;

float y[]={10.4,20.2,30.6,15.5};

cout<<” rmax(n,y)=”<<rmax(n,y)<<” ”;

rmax(4,y)=0;

for(in i=0;i<n;i++)

cout<<y[i]<<” “;

cout<<” ”;

}

Результаты:

rmax(n,x)=30

10 20 0 15

rmax(n,y)=30.6

10.4 20.2 0 15.5

Основные свойства параметров шаблона функций

1. Имена параметров должны быть уникальными во всем определении шаблона.

2. Список параметров шаблона не может быть пустым.

3. В списке параметров шаблона может быть несколько параметров, каждый из них начинается со слова class.