泛型编程

来源:互联网 发布:金税盘开票软件口令 编辑:程序博客网 时间:2024/06/07 06:17

@讲师张文杰—Geekband

这里写图片描述

1.概观

这里写图片描述

  • 将型别以一种 to-be-specified-later 方式给出
  • 通过模板以及相关性质表现的

2.Traits

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

…实际调试一遍

3.迭代器

  • 分离算法和容器

这里写图片描述

这里写图片描述

这里写图片描述

4.容器


容器的种类
1.vector
2.list
3.deque
4.set and Multiset
5.Map and MultiMap
6.stack
7.Queue


1.vector

这里写图片描述

  1. 能够存放任意型别的动态数组
  2. 一段地址连续的空间
  3. 动态的空间调整
  4. 向vector添加元素
//vector的声明#include<vector> int main(){    std::vector v;}

这里写图片描述

push_back函数

向vector添加元素的方法,调用该函数,将元素加至其尾部

std::vector<std::wstring> v3;for(std::size_t i=0;i<10;i++){    std::wstringstream wss;    wss<<TEXT("String[")<<i<<TEXT("]"));    v3.push_back(wss.str());}

empty()函数
size()函数

std::vector<std::wstring> v3;bool isEmpty = v3.empty();int array[] = {1,2,3,4,5,6,7,8,9,10};std::vector<int> v(array,array+10);std::size Vsize = v.size();

访问vector中的元素
vector::at()
vector:operator[]

这里写图片描述

这里写图片描述

std::vector<std::wstring> v;v.reserve(10);for(std::size_t i=0;i<3;i++){    std::wstringstream wss;    wss<<TEXT("String[")<<i<<TEXT("]");    v.push_back(wss.str());}try{    std::wstring wsz1 = v[5];    std::wstring wsz2 = v.at(5);}catch(const std::exception& e){    Console::WriteLine(ex.what());}

C++里尽量少用try-catch,开销大。

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

2.Deque

这里写图片描述

3.List

这里写图片描述

这里写图片描述

  • 调试运行文件—test_fx
  • 使用list,必须用include,并通过std命名空间去访问

创建List
std::list l; 创建一个T型别的空list
std::list l(n);创建一个容量是n的T型别的list
std::list l(n,x); 创建一个容量是n的T型别的list,初始化为x
std::list copyOfList(l); 创建一个已有list的拷贝
std::wstring array[] = {TEXT(“Str-1”),TEXT(“Str-2”),TEXT(“Str-3”)};
std::list l(array,array+3);
通过一个数组创建一个list

常见操作

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

  • l.remove_if(ContainsString(TEXT(“C++”)));
  • //remove string that contains “C++”

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述


0 0
原创粉丝点击