百度百科

STL是Standard Template Library的简称,中文名标准模板库,惠普实验室开发的一系列软件的统称。从根本上说,STL是一些“容器”的集合,这些“容器”有list,vector,set,map等,STL也是算法和其他一些组件的集合。STL的目的是标准化组件,这样就不用重新开发,可以使用现成的组件。STL现在是C++的一部分,因此不用安装额外的库文件。

在C++标准中,STL被组织为下面的13个头文件:<algorithm>、<deque>、<functional>、<iterator>、<array>、<vector>、<list>、<forward_list>、<map>、<unordered_map>、<memory>、<numeric>、<queue>、<set>、<unordered_set>、<stack>和<utility>。

向量(vector)                            连续存储的元素<vector>

列表(list)                                 由节点组成的双向链表,每个结点包含着一个元素<list>

双队列(deque)                        连续存储的指向不同元素的指针所组成的数组<deque>

集合(set)                                 由节点组成的红黑树,每个节点都包含着一个元素,节点之间以某种作用于元素对的谓词排列,没有两个不同的元素能够拥有相同的次序 <set>

多重集合(multiset)                  允许存在两个次序相等的元素的集合 <set>

栈(stack)                                 后进先出的值的排列 <stack>

队列(queue)                            先进先出的执的排列 <queue>

优先队列(priority_queue)       元素的次序是由作用于所存储的值对上的某种谓词决定的的一种队列 <queue>

映射(map)                               由{键,值}对组成的集合,以某种作用于键对上的谓词排列 <map>

多重映射(multimap)               允许键对有相等的次序的映射 <map>

一、string

在定义 string 类对象时,string 类自身可以管理内存,程序员不必关注内存的分配细节。

string 类提供的各种操作函数大致分为八类:构造器和析构器、大小和容量、元素存取、字 符串比较、字符串修改、字符串接合、I/O 操作以及搜索和查找。

要使用 string 类,必须包含头文件 <string>

string stuff;
getline(cin, stuff); //获取一行字符串

1、构造函数

string strs                      //生成空字符串
string s(str) //生成字符串str的复制品
string s(str, stridx) //将字符串str中始于stridx的部分作为构造函数的初值
string s(str, strbegin, strlen) //将字符串str中始于strbegin、长度为strlen的部分作为字符串初值
string s(cstr) //以C_string类型cstr作为字符串s的初值
string s(cstr,char_len) //以C_string类型cstr的前char_len个字符串作为字符串s的初值
string s(num, c) //生成一个字符串,包含num个c字符
string s(strs, beg, end) //以区间[beg, end]内的字符作为字符串s的初值
string s('x');       //错误
string s(, 'x'); //正确
string s("x"); //正确

2、获取字符串长度

str.size();          //返回 string 类型对象中的字符个数
str.length(); //返回 string 类型对象中的字符个数
str.max_size(); //返回 string 类型对象最多包含的字符数。一旦程序使用长度超过 max_size() 的 string 操作,编译器会拋出 length_error 异常。
str.capacity(); //返回在重新分配内存之前string 类型对象所能包含的最大字符数。

3、获取字符串元素:

一般可使用两种方法访问字符串中的单一字符:下标操作符[] 和 成员函数at()。两者均返回指定的下标位置的字符。第 1 个字符索引(下标)为 0,最后的字符索引为 length()-1。

需要注意的是,这两种访问方法是有区别的:

  • 下标操作符 [] 在使用时不检查索引的有效性,如果下标超出字符的长度范围,会示导致未定义行为。对于常量字符串,使用下标操作符时,字符串的最后字符(即 '\0')是有效的。对应 string 类型对象(常量型)最后一个字符的下标是有效的,调用返回字符 '\0'。
  • 函数 at() 在使用时会检查下标是否有效。如果给定的下标超出字符的长度范围,系统会抛出 out_of_range 异常。
string s="abcd";
temp = str []; //获取字符 'c'
temp_1 = str.at(); //获取字符 'c'

4、字符串比较方法

Basic_string 类模板既提供了  >、<、==、>=、<=、!= 等比较运算符,还提供了 compare() 函数,其中 compare() 函数支持多参数处理,支持用索引值和长度定位子串进行比较。该函数返回一个整数来表示比较结果。如果相比较的两个子串相同,compare() 函数返回 0,否则返回非零值。

string A ("aBcdef");
string B ("AbcdEf");
string C ("");
string D ("123dfg");
//下面是各种比较方法
int m=A.compare (B); //完整的A和B的比较 32
int n=A.compare(,,B,,); //A的"Bcdef"和B的"bcdEf"比较 -32
int q=C.compare(,,D,,); //"123"和"123"比较 0

5、字符串内容的修改

可以通过使用多个函数修改字符串的值。例如 assign(),operator=,erase(),交换(swap),插入(insert)等。另外,还可通过 append() 函数添加字符。

str.assign(str1);                      //str1赋值给str
str.assign (str1 , , ); //将从str1[3]长度3的子串赋值给str
str.assign (str1, , str1.npos); //将从str1[2]到末尾赋值给str
str.assign (, 'X'); //将XXXXX赋值给str
string::iterator itB; //迭代器itB
itB = str1.begin (); //将str1.begin(),即1赋值给迭代器itB
str.erase(); //从尾开始,删除3个值
str.swap(str2); //str值与str2值交换
B.insert (, A); //在B[1]位置插入A
B.insert (, "yanchy ", ); //将“yanchy”长度为3的子串插入B[1]
B.insert(,A,,); //将A从索引2,长度为2的子串插入B[1]
B.insert (,,'C');
B.append (A); //将A追加到B后
B.append("", ); //将从索引0,长度为2的子串追加至B
B.append ("", , ); //将从索引2,长度为3的子串追加至B
B.append ( , 'a'); //追加10个a

6、字符串内容的替换

如果在一个字符串中标识出具体位置,便可以通过下标操作修改指定位置字符的值,或者替换某个子串。完成此项操作需要使用 string 类的成员函数 replace()。

var.replace (,, “”);
var.replace (, , , 'x');
var.replace (,, var1.c_str(), , );

7、字符串查找函数

str.find ('P', );
str.find (" some", );

二、序列容器

1、array

array<T,N> 模板定义了一种相当于标准数组的容器类型。它是一个有 N 个 T 类型元素的固定序列。除了需要指定元素的类型和个数之外,它和常规数组没有太大的差别。显然,不能增加或删除元素。

1.1初始化

array<double, > data;             //定义100个double型元素,但未初始化
array<double, > data {}; //初始化
array<double, > values {0.5, 1.0}; //创建 array 容器的实例时,对元素进行初始化
values.fill(3.14); //将所有元素设成给定值

1.2获取元素

values[] = values[] + .O*values[];            //索引
values.at () = values.at() + .O*values.at(); //at()
auto first = height_ins.begin(); //begin()
auto last = height_ins.end () ; //end()

2、vector

vector<T> 容器是包含 T 类型元素的序列容器,和 array<T,N> 容器相似,不同的是 vector<T> 容器的大小可以自动增长,从而可以包含任意数量的元素;因此类型参数 T 不再需要模板参数 N。只要元素个数超出 vector 当前容量,就会自动分配更多的空间。只能在容器尾部高效地删除或添加元素。

2.1初始化

vector<int> v {, , , , };  //以初始化列表中的値作为元素初始值,生成有 5 个int型 vector 容器
vector<double> values(); //容器开始时有 20 个元素,它们的默认初始值都为 0
vector<char >v (, 'a'); //容器开始时有 10 个元素,它们的默认初始值都为 char型 a
array<string> words {"one", "two","three", "four", "five"};
vector<string> words_copy {begin(words) , end(words)}; //元素复制
vector<string〉words_copy {make_move_iterator(begin(words)),make_move_iterator(end(words))}; //元素移动
struct Node{ 
//初始化结构体
//省略代码
};
vector<Node*>v;

2.2大小与容量

size()、capacity()

vector<size_t> v { , , , , , , , ,  };       //初始化
cout << "The size is " << v.size() << std::endl; //v.size() 计算元素个数
cout << "The capacity is" << v.capacity() << std::endl; //v.capacity() 计算容量大小

2.3获取元素

front()、back()、begin()、end()、索引

通过使用索引,总是可以访问到现有的元素或为现有元素设定值,但是不能这样生成新元素。

vector<double> v();
v[] = 3.14159;
v[] = 5.0;
v[] = 2.0*[]*v[];
cout << v.front () << endl;   //front()返回序列中第一个元素的引用
cout << v.front () << endl; //back()返回序列中最后一个元素的引用
v.front() = 2.71828; //因为返回的是引用,所以可以出现在赋值运算符的左边。
auto pData = v.data(); //返回一个指向数组的指针,它在内部被用来存储元素。data() 返回 vector<T> 容器的 T* 类型的值。

2.4添加元素

push_back()、emplace_back()、insert()

emplace_back() 函数会调用接收三个参数的 string 构造函数,生成 string 对象,然后把它添加到 words 序列中。构造函数会生成一个从索引 2 幵始、包含 str 中三个字符的子串。

vector<int> v;
v.push_back(); //push_back()把3添加到现有元素的后面 string str {"alleged"};
words.emplace_back(str, , ); // "leg" in place  

insert()

1) 插入第二个参数指定的单个元素

vector<string> words { "one","three","eight"}     //初始化
auto iter = words.insert(++begin(words), "two"); //one two three eight 返回的迭代器指向被插入的元素 string(”two”)

2) 插入一个由第二个和第三个参数指定的元素序列

string more[] {"five", "six", "seven" };                          //初始化
auto iter = words.insert(--end(words) ,begin(more), end(more)); //one two three five six seven eight 返回的迭代器指向插入的第一个元素"five"。

3) 在插入点插入多个单个元素。第二个参数是第三个参数所指定对象的插入次数

vector<int> words{ ,, };                    //初始化
auto iter = words.insert(--end(words), , ); //1 2 3 3 4

2.5删除元素

clear()、pop_back()、erase()
v.clear();                      //删除所有元素
v.pop_back(); //删除尾部元素
v.erase(begin(v) + ); //删除第二个元素 vector<int> v{ ,,,, }; //删除范围内的元素,左闭右开
v.erase(begin(v)+,begin(v)+); //1,4,5

2.6其他

v.empty()                       //判空
v1.swap(v2) //交换容器间数据
reverse(v.begin(), v.end()); //反转

3、deque

deque<T>,一个定义在 deque 头文件中的容器模板,可以生成包含 T 类型元素的容器,它以双端队列的形式组织元素。可以在容器的头部和尾部高效地添加或删除对象,这是它相对于 vector 容器的优势。

3.1初始化

deque<int> d;                                                //生成deque容器,容器中没有元素,因此添加第一个元素,就会导致内存的分配
deque<int> d(); //10个元素,默认值为0
deque<string> words { "one", "none", "some", "all" }; //初始化
deque<string> words_copy { words }; //生成words的副本
deque<string> words_part { begin(words),begin(words) + }; //迭代器标识范围初始化

3.2获取元素

索引、at()、front()、back()

3.3大小

size(); 因为deque容量和大小总是一样,所以并没有capacity()

3.4添加和删除元素

与vector一样都有成员函数:push_back()、pop_back()、emplace_back()、insert()、erase()、clear()

deque还有:push_front()、pop_front()、emplace_front()

3.5修改替换元素

assign()

4、List

list<T> 容器模板定义在 list 头文件中,是 T 类型对象的双向链表。

4.1初始化

list<string> l;
list<string> l {}; //二十个元素
list<double> l (, 3.14); //50个3.14
list<double> l {l1}; //生成l1(list容器)的副本
list<double> l {++cbegin(l1), --cend(l1)}; //l1的开始和结束迭代器所指定的一段元素

4.2大小

size()

4.3添加删除元素

添加:

push_back()、push_front()、emplace_back()、emplace_front(),后两个函数更高效。

insert(),插入元素不必移动现有的元素。生成新元素后,这个过程需要将 4 个指针重新设为适当的值。第一个元素的 next 指针指向新的元素,原来的第二个元素的 pre 指针也指向新的元素。新元素的 pre 指针指向第一个元素,next 指针指向序列之前的第二个元素。

删除:

clear()、erase(),list 容器的成员函数 remove() 则移除和参数匹配的元素。

成员函数 remove_if() 期望传入一个一元断言作为参数。一元断言接受一个和元素同类型的参数或引用,返回一个布尔值。断言返回 true 的所有元素都会被移除。

numbers.remove_if([](int n){return n% == ;});   // Remove even numbers. Result 5 3 7 9

成员函数 unique()可以移除连续的重复元素,只留下其中的第一个。

list<string> words { "one", "two", "two", "two","three", "four", "four"};
words.unique () ; // Now contains "one" "two" "three" "four"

4.4排序与合并元素

list 容器并不提供随机访问迭代器,只提供双向迭代器,因此不能对 list 中的元素使用 sort() 算法,而是定义了自己的 sort() 函数。

names.sort(greater<>()); //从大到小排序,头文件 functional 中的模板 greater<T>
names.sort(cmp()); //或者自定义比较函数

list 的成员函数 merge() 以另一个具有相同类型元素的 list 容器作为参数。两个容器中的元素都必须是升序。参数 list 容器中的元素会被合并到当前的 list 容器中。

list<int> my{, , , };
list<int> your{ -, , , };
my.merge (your); //my: -2 1 2 4 6 7 10 14
your.empty(); //your变为空

list 容器的成员函数 splice() 有几个重载版本。这个函数将参数 list 容器中的元素移动到当前容器中指定位置的前面。可以移动单个元素、一段元素或源容器的全部元素。

三、容器适配器

1、stack

stack<T>:是一个封装了 deque<T> 容器的适配器类模板,默认实现的是一个后入先出(Last-In-First-Out,LIFO)的压入栈。stack<T> 模板定义在头文件 stack 中。

  • top():返回一个栈顶元素的引用,类型为 T&。如果栈为空,返回值未定义。
  • push():可以将对象副本压入栈顶。这是通过调用底层容器的 push_back() 函数完成的。
  • pop():弹出栈顶元素。
  • size():返回栈中元素的个数。
  • empty():在栈中没有元素的情况下返回 true。
  • swap(stack<T> & other_stack):将当前栈中的元素和参数中的元素交换。参数所包含元素的类型必须和当前栈的相同

2、queue

queue<T>:是一个封装了 deque<T> 容器的适配器类模板,默认实现的是一个先入先出(First-In-First-Out,LIFO)的队列。queue<T> 模板定义在头文件 queue 中。

  • front():返回 queue 中第一个元素的引用。如果 queue 是常量,就返回一个常引用;如果 queue 为空,返回值是未定义的。
  • back():返回 queue 中最后一个元素的引用。如果 queue 是常量,就返回一个常引用;如果 queue 为空,返回值是未定义的。
  • push():在 queue 的尾部添加一个元素的副本。这是通过调用底层容器的成员函数 push_back() 来完成的。
  • pop():删除 queue 中的第一个元素。
  • size():返回 queue 中元素的个数。
  • empty():如果 queue 中没有元素的话,返回 true。
  • swap(queue<T> &other_q):将当前 queue 中的元素和参数 queue 中的元素交换。它们需要包含相同类型的元素。也可以调用全局函数模板 swap() 来完成同样的操作。

priority_queue<T>:是一个封装了 vector<T> 容器的适配器类模板,默认实现的是一个会对元素排序,从而保证最大元素总在队列最前面的队列。                                                                                           priority_queue<T> 模板定义在头文件 queue 中。

  • push():将obj放到容器的适当位置,这通常会包含一个排序操作。
  • top():返回优先级队列中第一个元素的引用。
  • pop():移除第一个元素。
  • size():返回队列中元素的个数。
  • empty():如果队列为空的话,返回true。
  • swap(priority_queue<T>& other):和参数的元素进行交换,所包含对象的类型必须相同

四、map容器

map 容器是关联容器的一种。在关联容器中,对象的位置取决于和它关联的键的值。

map 和 mutilmap 容器的模板定义在 map 头文件中,unordered_map 和 unordered_multimap 容器的模板定义在 unordered_map 头文件中。

map 容器有 4 种,每一种都是由类模板定义的。每种 map 容器的模板都有不同的特性:

  1. map<K,T>容器,保存的是 pair<const K,T> 类型的元素。键唯一;map 容器中的元素都是有序的,元素在容器内的顺序是通过比较键确定的。
  2. multimap<K,T> 容器,也会对元素排序。元素的顺序是通过比较键确定的。但multimap 容器可以保存多个具有相同键值的 <const K,T> 元素。
  3. unordered_map<K,T> 中 pair< const K,T>元素的顺序是由键值的哈希值决定的。不允许有重复的键。
  4. unordered_multimap<K,T> 通过键值生成的哈希值来确定对象的位置,但允许有重复的键。

区别: multi前缀表明键不必唯一

unordered前缀表明容器中元素的位置是通过其键值所产生的哈希值来决定的,而不是通过比较键值决定的。

STL用法整理的更多相关文章

  1. Spring JdbcTemplate用法整理

    Spring JdbcTemplate用法整理: xml: <?xml version="1.0" encoding="UTF-8"?> <b ...

  2. linq用法整理

    linq用法整理 普通查询 var highScores = from student in students where student.ExamScores[exam] > score se ...

  3. linux学习:特殊符号,数学运算,图像与数组与部分终端命令用法整理

    指令:let.expr.array.convert.tput.date.read.md5.ln.apt.系统信息 一:特殊符号用法整理 系统变量 $# 是传给脚本的参数个数 $0 是脚本本身的名字 $ ...

  4. #ifndef#define#endif的用法(整理)

    [转] #ifndef#define#endif的用法(整理)    原作者:icwk  文件中的#ifndef 头件的中的#ifndef,这是一个很关键的东西.比如你有两个C文件,这两个C文件都in ...

  5. Google Guava 库用法整理<转>

    参考: http://codemunchies.com/2009/10/beautiful-code-with-google-collections-guava-and-static-imports- ...

  6. MySQL中使用SHOW PROFILE命令分析性能的用法整理(配合explain效果更好,可以作为优化周期性检查)

    这篇文章主要介绍了MySQL中使用show profile命令分析性能的用法整理,show profiles是数据库性能优化的常用命令,需要的朋友可以参考下   show profile是由Jerem ...

  7. Android spannableStringBuilder用法整理

    Android spannableStringBuilder用法整理 分类: Android开发2013-11-29 10:58 5009人阅读 评论(0) 收藏 举报 Androidspannabl ...

  8. OBJECTPROPERTY用法整理

    OBJECTPROPERTY用法整理 分类: 系统表与表结构 数据库管理维护2010-06-03 16:37 2783人阅读 评论(1) 收藏 举报 数据库sql serverinsertobject ...

  9. 算法拾遗[4]——STL用法

    主要bb一下优先队列和字符串吧. 哦还有 bitset. 优先队列 定义很容易: priority_queue<int> pq; 内部是一个堆. 基本操作 pq.top() 取堆顶元素; ...

随机推荐

  1. 学习ASP.NET Core Razor 编程系列十六——排序

    学习ASP.NET Core Razor 编程系列目录 学习ASP.NET Core Razor 编程系列一 学习ASP.NET Core Razor 编程系列二——添加一个实体 学习ASP.NET ...

  2. [翻译] 使用 Python 创建你自己的 Shell:Part II

    目录 使用 Python 创建你自己的 Shell:Part II 原文链接与说明 步骤 4:内置命令 最后的想法 使用 Python 创建你自己的 Shell:Part II 原文链接与说明 htt ...

  3. 从零开始学习iftop流量监控(找出服务器耗费流量最多的ip和端口)

    一.iftop是什么 iftop是类似于top的实时流量监控工具. 作用:监控网卡的实时流量(可以指定网段).反向解析IP.显示端口信息等 官网:http://www.ex-parrot.com/~p ...

  4. SLAM+语音机器人DIY系列:(四)差分底盘设计——4.底盘ROS驱动开发

    摘要 运动底盘是移动机器人的重要组成部分,不像激光雷达.IMU.麦克风.音响.摄像头这些通用部件可以直接买到,很难买到通用的底盘.一方面是因为底盘的尺寸结构和参数是要与具体机器人匹配的:另一方面是因为 ...

  5. 关于单链表的增删改查方法的递归实现(JAVA语言实现)

    因为在学习数据结构,准备把java的集合框架底层源码,好好的过一遍,所以先按照自己的想法把单链表的类给写出来了; 写该类的目的: 1.练习递归 2.为深入理解java集合框架底层源码打好基础 学习的视 ...

  6. html和css的使用方法以及样式

    布局步骤 第一步: 清除默认样式第二步: 划分模块第三步: 设置模块的大小以及位置第四步: 划分下一级模块 html和css 引入网页头像 <link rel="shortcut ic ...

  7. web服务器负载均衡与集群基本概念二

    前面已经说过负载均衡的作用是在多个节点之间按照一定的策略(算法)分发网络或计算处理负载.负载均衡可以采用软件和硬件来实现.一般的框架结构可以参考下图.    后台的多个Web节点上面有相同的Web应用 ...

  8. MongoDB自学(3)

    MongoDB关系:MongoDB的关系表示多个文档之间在逻辑上的相互联系.文档之间可以通过嵌入和引用来建立联系.关系:1:11:NM:1M:N 嵌入式:{ id:11;name:嘻嘻嘻;addres ...

  9. 搭建 structs2 环境

    前言 环境: window 10 ,JDK 1.8 ,Tomcat 7 ,MyEclipse 2014 pro 搭建 SSH 环境的步骤 创建 JavaWeb 项目 导入 structs2 的jar包 ...

  10. Mac Git 安装和配置

    一.git下载与安装 点击Git,然后选择下载安装包 git --version,终端输入该命令, 如输出版本号,则说明安装成功. git version 2.20.1 二.git基本配置 通过下面这 ...