Cpp9 模板

Cpp9 模板

模板

下面是一个针对int的冒泡排序

// _20180301.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"

void Sort(int* arr,int nLength)
{
    int i,k;
    for (i = 0;i<nLength;i++)
    {
        for (k=0;k<nLength-1-i;k++)
        {
            if(arr[k]>arr[k+1])
            {
                int temp = arr[k];
                arr[k] = arr[k+1];
                arr[k+1]=temp;
            }
        }
    }
}

int main(int argc, char* argv[])
{
    int arr[] = {1,4,5,2,7,8,3,12,56,879};
    Sort(arr,10);

    return 0;
}

如果想要其他任意类型的使用此排序方法呢
此时引出模板

// _20180301.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"

template<class T>
void Sort(T* arr,int nLength)
{
    int i,k;
    for (i = 0;i<nLength;i++)
    {
        for (k=0;k<nLength-1-i;k++)
        {
            if(arr[k]>arr[k+1])
            {
                T temp = arr[k];
                arr[k] = arr[k+1];
                arr[k+1]=temp;
            }
        }
    }
}

int main(int argc, char* argv[])
{
    int arr[] = {1,4,5,2,7,8,3,12,56,879};
    Sort(arr,10);
    char arr2[] = {'a','b','c','t','m'};
    Sort(arr2,5);

    return 0;
}

在函数中使用模板格式

template <class 形参名,class 形参名, ....>
返回类型 函数名(形参列表)
{
    函数体
}

自定义类型使用模板

// _20180301.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"

class Base
{
public:
    Base(int x,int y)
        :x(x),y(y)
    {
    }
    bool operator>(const Base& base)
    {
        return this->x > base.x && this->y > base.y;
    }

private:
    int x;
    int y;
};

template<class T>
void Sort(T* arr,int nLength)
{
    int i,k;
    for (i = 0;i<nLength;i++)
    {
        for (k=0;k<nLength-1-i;k++)
        {
            if(arr[k]>arr[k+1])
            {
                T temp = arr[k];
                arr[k] = arr[k+1];
                arr[k+1]=temp;
            }
        }
    }
}

int main(int argc, char* argv[])
{
    int arr[] = {1,4,5,2,7,8,3,12,56,879};
    Sort(arr,10);
    char arr2[] = {'a','b','c','t','m'};
    Sort(arr2,5);

    Base b1(1,1),b2(4,4),b3(6,6),b4(2,2),b5(8,8);
    Base arr3[]={b1,b2,b3,b4,b5};

    Sort(arr3,5);

    return 0;
}

在架构提、类中使用模板

类模板的格式为:

template<class 形参名,class 形参名,...>
class 类名
{
}

例子:

// _20180301.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"

template<class T,class M>
class Base {

private:
    T x;
    T y;

    M a;
    M b;
public:
    Base(T tx,T ty,M ma,M mb)
        :x(tx),y(ty),a(ma),b(mb)
    {
    }
    T max()
    {
        if (x>y)
            return x;
        else
            return y;
    }

    M min()
    {
        if(a<b)
            return a;
        else 
            return b;
    }

};



int main(int argc, char* argv[])
{
    Base<int,char> base(1,2,'a','z');
    
    int max = base.max();
    char min = base.min();
    return 0;
}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,779评论 18 399
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,638评论 25 708
  • 我一直在这个尘世奔走,记不清具体多少天,大概有六年了吧。 回头看,我的足迹是一堆乱麻,有的走向是朝向你的,而有的走...
    枫橋阅读 414评论 0 4
  • 林城的夏季,异常的燥热,每一滴滴落在水泥地上的汗珠,均无力地挣扎着,随着“刺啦”一声,便消失在尘埃中,毫无痕迹,仿...
    浅诺清若阅读 362评论 0 1
  • 币圈的活跃度增加的越来越多?最近场外资金全线进入 推荐几本书吧。原则。人类简史
    币风港阅读 187评论 0 0