泛型语义

  泛型(Generic Programming),即是指具有在多种数据类型上皆可操作的含意。泛型编
程的代表作品 STL 是一种高效、泛型、可交互操作的软件组件。
  泛型编程最初诞生于 C++中,目的是为了实现 C++的 STL(标准模板库)。其语言支
持机制就是模板(Templates)。
  模板的精神其实很简单:类型参数化(type parameterized),即,类型也是一种参数,
也是一种静多态。 换句话说, 把一个原本特定于某个类型的算法或类当中的类型信息抽掉,
抽出来做成模板参数。

stack类

Stack 类模板化,可以 push 和 pop 不同的数据类型。主要由几个因素需要把控。栈
中的空间元素类型,压入元素类型,弹出元素类型,三者保持一致即可。

#include <iostream>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
using namespace std;

class Stack{
  public:
  Stack(int size=1024){
    space = new int[size];
    top = 0;
  }

~Stack(){
  delete []space;
}

bool isEmpty(){
return top == 0;
}
bool isFull(){
return top == 1024;
}

void push(int data){
space[top++] = data;
}

int pop(){
return space[--top];
}
private:
int* space;
int top;
};
int main()
{
  Stack s(100);
  for(int i=0; i<10; ++i){
  if(!s.isFull())
  s.push(i);
  }

  while(!s.isEmpty())
  cout<<s.pop()<<endl;
  return 0;
}

类模板

格式:

应用:

ClassName<int> cn; //类模板->模板类->类对象

Stack类模板

#include <iostream>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
using namespace std;

template<typename T>class Stack
{
public:
Stack(int size=1024);
~Stack();
bool isEmpty();
bool isFull();
void push(T data);
T pop();

private:

T* space;
int top;
};

template<typename T> Stack<T>::Stack(int size)
{
  space = new T[size];
  top = 0;
}
template<typename T> Stack<T>::~Stack(){
  delete []space;
}

template<typename T>bool Stack<T>::isEmpty(){
  return top == 0;
}

template<typename T>bool Stack<T>::isFull(){
  return top == 1024;
}

template<typename T>void Stack<T>::push(T data){
  space[top++] = data;
}

template<typename T> T Stack<T>::pop(){
  return space[--top];
}

int main()
{
  Stack<string> s(100);
  for(int i=0; i<10; ++i){
    if(!s.isFull())
    s.push(to_string(i)+"-abc");
  }
while(!s.isEmpty())
  cout<<s.pop()<<endl;
  return 0;
}

  类的模板本质上就是函数模板的应用,将抽象化的函数租组织到一个类 模板 内,类名的本质就是一个命名空间。

template<typename T> class XXX从格式上区别于类,完成了对类进行抽象。

 

类模板的友元

#include <iostream>
#include <istream>
#include <ostream> using namespace std; //类内实现友元
template<typename T>
class Complex
{
  friend
  istream & operator>> (istream & in, Complex<T>& c)
  {
    in>>c.real>>c.image;
    return in;
  }
  friend
  ostream & operator<< (ostream & out, Complex<T> & c)
  {
    cout<<"("<<c.real<<","<<c.image<<")"<<endl;
    return out;
  }
  private:
   T real;
   T image;
};
int main()
{
  Complex<double> c;
  cin>>c;
  cout<<c;
  return 0;
}

类外实现友元

1 )类前声明
2 )friend 类中声明 <>
3 )类外实现

#include <iostream>
#include <istream>
#include <ostream>

using namespace std;

//①类前声明
template<typename T> class Complex;
template<typename T> istream & operator>> (istream & in, Complex<T>& c);
template<typename T> ostream & operator<< (ostream & out, Complex<T> & c);
  
template<typename T>
class Complex
{

  //②freind类中声明<>
  friend istream & operator>> <>(istream & in, Complex<T>& c);
  friend ostream & operator<< <>(ostream & out, Complex<T> & c);
private:
  T real;
  T image;
};


//③类外实现
template<typename T>
istream & operator>> (istream & in, Complex<T>& c)
{
  in>>c.real>>c.image;
  return in;
}

template<typename T> ostream & operator<< (ostream & out, Complex<T> & c) 
{   
  cout<<"("<<c.real<<","<<c.image<<")"<<endl;   
  return out;
}

int main()
{
  Complex<double> c;
  cin>>c;
  cout<<c;
  return 0;
}

hpp

《C++编程思想》第 15 章(第 300 页):
  模板定义很特殊。由 template<…> 处理的任何东西都意味着编译器在当时不为它分
配存储空间, 它一直处于等待状态直到被一个模板实例告知。 在编译器和连接器的某一处,
有一机制能去掉指定模板的多重定义。所以为了容易使用,几乎总是在头文件中放置全部
的模板声明和定义,文件后缀为.hpp。

C++泛型编程之类模板的更多相关文章

  1. c++ 泛型编程及模板学习

    泛型编程,英文叫做Generic programming 可以理解为,具有通用意义的.普适性的,编程. 比如,你要实现一个函数去比较两个数值的大小,数值可能是int或者string.初次尝试,我们直观 ...

  2. 26.C++- 泛型编程之类模板(详解)

    在上章25.C++- 泛型编程之函数模板(详解) 学习了后,本章继续来学习类模板   类模板介绍 和函数模板一样,将泛型思想应用于类. 编译器对类模板处理方式和函数模板相同,都是进行2次编译 类模板通 ...

  3. 25.C++- 泛型编程之函数模板(详解)

    本章学习: 1)初探函数模板 2)深入理解函数模板 3)多参函数模板 4)重载函数和函数模板 当我们想写个Swap()交换函数时,通常这样写: void Swap(int& a, int&am ...

  4. C++ 模板 与 泛型编程

    C++ 模板 与 泛型编程 前言 模板有两种:类模板和函数模板 .模板是泛型编程的基础. 什么叫:泛型编程? 使用独立于特定类型的方式进行编程.也就是我们在编程的时候不明确的写上类型,而是使用一个模板 ...

  5. C/C++程序基础 (十)模板和泛型

    什么是泛型编程 基于模板,有效将算法和数据结构分离. 模板 包括类型和参数 模板函数:抽象的函数定义,代表一类同构函数.编译器在其调用位置自动完成对应模板函数的实例化. 模板类:抽象的类定义,代表更高 ...

  6. Template 基础篇-函数模板(待看

    Template 基础篇-函数模板 Template所代表的泛型编程是C++语言中的重要的组成部分,我将通过几篇blog对这半年以来的学习做一个系统的总结,本文是基础篇的第一部分. Template ...

  7. C++ 模板应用浅析

    把曾经写的C++模板的应用心得发表出来. 回忆起当时在学习C++模板时的无助和恐惧,如今还心有余悸.我分享出来我的心得,仅仅希望别人少走弯路,事实上它就这么几种使用方法,不须要害怕. 我总结了模板的四 ...

  8. C++中函数模板的概念和意义

    1,对泛型编程进行学习,泛型编程是实际工程开发中必用的技术,大型公司的通用 库都是采用泛型编程的技术完成的,C++ 中支持泛型编程技术,C++ 中的函数  模板和类模板就是 C++ 中泛型编程技术,本 ...

  9. 读书笔记_Effective_C++_条款四十一:了解隐式接口和编译期多态

    从本条款开始,就进入了全书的第七部分:模板与泛型编程.模板与泛型在C++中是非常重要的部分,还记得本书第一章时,把C++视为一个联邦,它由四个州政府组成,其中一个政府就是模板与泛型了. 本条款是一个介 ...

随机推荐

  1. .Net Core with 微服务 - Polly 服务降级熔断

    在我们实施微服务之后,服务间的调用变的异常频繁.多个服务之间可能是互相依赖的关系.某个服务出现故障或者是服务间的网络出现故障都会造成服务调用的失败,进而影响到某个业务服务处理失败.某一个服务调用失败轻 ...

  2. ArrayList 深入浅出

    ArrayList 特点:按添加顺序排列.可重复.非线程安全: 底层实现:数组 扩容原理:初始化集合时,默认容量为 0,第一次添加元素时扩容为 10,容量不够时扩容为原来容量的 1.5 倍. 这里扩容 ...

  3. IO编程之对象序列化

    对象序列化的目标是将对象保存在磁盘中或者允许在网络中直接传输对象.对象序列化机制循序把内存中的java对象转换成平台无关的二进制流,从而允许把这种二进制流持久的保存在磁盘上,通过网络将这种二进制流传输 ...

  4. 分别在Update和FixedUpdate使用GetKeyDown

    测试目的 探究分别在Update和FixedUpdate使用GetKeyDown执行次数,会不同的 测试开始 在Update测试 我们先在Update测试,很正常是一帧重置一下状态,以防止点击一下执行 ...

  5. 标准化R包开发流程

    3个武器: devtools:各种开发小工具的合集,让开发变得简单,非常实用 roxygens:通过注释的方式,生成文档,远离LaTex的烦恼 testthat:单元测试,让R包稳定.健壮.减少升级的 ...

  6. C++第四十一篇 -- 安装成功的第一个驱动文件

    参考链接:https://blog.csdn.net/LEON1741/article/details/87291839 一.新建工程 二.写一个Driver.c #include <ntddk ...

  7. 第十六篇 -- SuperIO学习

    一.SuperIO 这次主要研究SuperIO读取以及控制风扇转速的问题. 参考文章:https://huchanghui123.github.io/Linux/Linux-Superio-CPU-F ...

  8. kubernetes/k8s CRI分析-容器运行时接口分析

    关联博客:kubernetes/k8s CSI分析-容器存储接口分析 概述 kubernetes的设计初衷是支持可插拔架构,从而利于扩展kubernetes的功能.在此架构思想下,kubernetes ...

  9. 构建前端第9篇之(下)---vue3.0将template转化为render的过程

    vue3.0将template转化为render的过程 这里是简单标记下,如何将.vue转换成js文件 具体的,先不研究了,太深,能力有限,达不到呢

  10. 随处可编辑的编辑器之神VIM

    据说这世界上只有三种编辑器:Vim,Emacs 和 其他编辑器,其中 Vim 被称作编辑器之神,Emacs 被称作神的编辑器,当然,其他编辑器永远只能是其他编辑器. 拿一位 网友的话 来说,VIM 的 ...