深入学习c++--容器
1. 简介
1. 序列式容器: array, vector, deque, list, forward_list --- 数组 或者 指针实现
2. 关联容器: set, map, multiset, multimap --- 二叉树 红黑树 O(logn)
3. 无顺序容器: unordered_map, unordered_set, unordered_multimap, unordered_multiset
补充拓展:
4. stack
5. queue
6. priority_queue
7. string
8. bitset: (0或1)
2. 元素要求
1. 元素必须 可以被赋值操作来复制或者搬移(因为容器和算法对复写的要求)
2. 元素必须可以被销毁
3. 对于序列容器,元素 必须有默认的构造函数
4. 对于某些操作, 元素需要定义 ==
5. 对于关联容器,排序准则默认的是: <, std:less
6. 无顺序容器,必须要提供一个 hash函数, 需要 ==
7. stl容器里面 存的是元素的值,而不是引用
8. 容器里面应该存放:
- 基本元素
- class : 满足上述
9. stl的设计原则是效率优先,安全为次
3. 容器的通用接口
4. 基本使用
4.1 array
4.2 vector
使用这些容器的过程中,我们会大量用到的操作就是插入操作,比如vector的push_back,map的insert,set的insert。这些插入操作会涉及到两次构造,首先是对象的初始化构造,接着在插入的时候会复制一次,会触发拷贝构造。但是很多时候我们并不需要两次构造带来效率的浪费,如果可以在插入的时候直接构造,就只需要构造一次就够了。
C++11标准已经有这样的语法可以直接使用了,那就是emplace。vector有两个函数可以使用:emplace,emplace_back。emplace类似insert,emplace_back类似push_back。
摘自:https://blog.csdn.net/windpenguin/article/details/75581552
4.3 deque
deque(双端队列)是一个动态数组,可以向两端发展,因此不论在尾部或头部安插元素都十分迅速。 在中间部分安插元素则比较费时,因为必须移动其它元素。
4.4 list
list用自己内置的算法比较好
4.6 forward_list
不能随机访问
4.7 set
频繁使用插入删除,可以考虑使用之。
4.8 map
emplace()构造生成的时候是以move的方式,来放到位置上去的
b.emplace(std::pair<const int, std::string>(10, std::string("aga"));
推荐用emplace来代替insert
map的[]形式,必须有默认构造函数(不推荐)
4.9 unordered_map(c++11)
优点:效率很高,查找删除是常数算法
缺点:空间上用的多,无序,适合一千万以下数据。
#include <iostream>
#include <set>
#include <string>
#include <algorithm>
#include <unordered_map>
using namespace std; class Position{
public :
int x() const { return m_x; }
int y() const { return m_y; }
private:
int m_x = ;
int m_y = ;
}; // 使用unordered_map需要实现这个
namespace std {
template<> struct hash<Position> {
size_t operator() (const Position& p) const { //对Postion做Hash ,模板类刻画
return p.x() + p.y();
}
};
} class Person {
private:
int m_age;
string m_name;
public:
Person(int a, string n) : m_age(a), m_name(move(n)) { }
int age() const {
return m_age;
}
const string& name() const {
return m_name;
}
void print() const { cout << m_age << " : " << m_name << endl; }
void changeAge(int newAge) { m_age = newAge; }
bool operator == (Person const& rhs) const {
return m_age == rhs.m_age && m_name == rhs.m_name;
} }; void testUnordered_map()
{
using Group = std::unordered_map<Position, Person>;
Group group;
}
//
//struct CompareAge {
// template<typename T>
// bool operator()(const T& t1, const T& t2) const {
// return t1.age() < t2.age();
// }
//}; int main()
{
testUnordered_map(); return ;
}
深入学习c++--容器的更多相关文章
- Spring.NET依赖注入框架学习--实例化容器常用方法
Spring.NET依赖注入框架学习---实例化容器常用方法 本篇学习实例化Spring.NET容器的俩种方式 1.通过XmlObjectFactory创建一个Spring.NET容器 IResour ...
- 5.docker学习之容器
容器创建 我们已经知道,镜像是只读的,而基于镜像创建出来的容器是可读写的,所以,一般我们实际中,会经常使用对应镜像创建容器并且使用这些容器.同样,如果我们想要使用容器,那么我们必须首先需要创建容器.而 ...
- c++学习之容器细枝末节(2)
从昨天到现在,还依然停留在容器的学习上,现在写例程代码顺手多了,看来写代码还是要多多练习才能有感觉. 经过一天的学习,有一下几点知识点让我觉得很有意义: (1)删除容器中的元素的时候,pop_fron ...
- c++学习之容器细枝末节(1)
对照着c++primier 开始学习第九章容器,把课后习题当做练习,虽然是看过书上的讲解,但是做题编程的时候,一些需要注意的地方还是难免有遗漏. 一下是几点印象比较深刻的总结: (1)前几章只学了ve ...
- ###STL学习--关联容器
点击查看Evernote原文. #@author: gr #@date: 2014-08-23 #@email: forgerui@gmail.com STL中的关联容器. ###stl学习 |--迭 ...
- 创建ApplicationContext与BeanFactory时的区别-Spring源码学习之容器的基本实现
传送门 可以加载XML两种方法 使用 BeanFactory 加载 XML BeanFactory bf = new XmlBeanFactory(new ClassPathResource(&quo ...
- 侯捷STL学习(十)--容器hashtable探索(unordered set/map)
layout: post title: 侯捷STL学习(十) date: 2017-07-23 tag: 侯捷STL --- 第二十三节 容器hashtable探索 hashtable冲突(碰撞)处理 ...
- spring源码学习之容器的基本实现
最近想拿出一部分时间来学习一下spring的源码,还特意买了一本书结合来看,当然主要是学习并跟着作者的思路来踏上学习spring的源码的道路,特意在此记录一下,<spring源码深度解析> ...
- laravel学习:容器绑定与解析
1.在服务容器中注册类(bind) $this->app->bind('sender','MailSender');//$this->app成为服务容器. 2.从服务容器生成类( ...
- Spring源码学习之容器的基本实现(一)
前言 最近学习了<<Spring源码深度解析>>受益匪浅,本博客是对学习内容的一个总结.分享,方便日后自己复习或与一同学习的小伙伴一起探讨之用. 建议与源码配合使用,效果更嘉, ...
随机推荐
- for循环中嵌套异步请求问题
for循环中嵌套了异步请求会导致顺序错乱,用递归代替for循环,可以保证正常执行顺序:
- 快速开平方取倒数的算法--嵌入式ARM转载
#include<stdio.h> #include<string.h> #include <stdlib.h> /* atof */ /* 计算=1/sqrt(n ...
- 通过 ffmpeg 获取视频第一帧(指定时间)图片
最近做一个上传教学视频的方法,上传视频的同时需要上传视频缩略图,为了避免用户上传的缩略图与视频内容不符,经理要求直接从上传的视频中截图视频的某一帧作为缩略图,并给我推荐了FFMPEG.FFMPEG 功 ...
- Spring框架 IOC注解
Spring框架的IOC之注解方式的快速入门 1. 步骤一:导入注解开发所有需要的jar包 * 引入IOC容器必须的6个jar包 * 多引入一个:Spring ...
- Linux 之 光标消失隐藏术
下面是 Linux 光标突然不见的解决办法: 直接敲命令行就行 echo -e "\033[?25l" 隐藏光标 echo -e "\033[?25h" 显示 ...
- HDU - 4352 - XHXJ's LIS(数位DP)
链接: https://vjudge.net/problem/HDU-4352 题意: a 到 b中一个数组成递增子序列长度等于k的数的个数 思路: 因为只有10个数,使用二进制维护一个递增序列,每次 ...
- 017_Python3 数据结构
本章节我们主要结合前面所学的知识点来介绍Python数据结构. ***************************** 1.列表 Python中列表是可变的,这是它区别于字符串和元组的最重 ...
- man、whatis、apropos命令
man命令类似于Linux的帮助文档. 1.man1提供给普通用户的可执行命令说明: 输入man 1 ls 后,结果如下: 结果分析: (1)NAME:命令的名称: (2)SYNOPSIS:参数的使用 ...
- WAMP 403 Forbidden禁止访问,别的电脑访问不了;
直接上图: 1:修改httpd.conf; deny from all 改成------ allow from all 重启服务就好了: 2:如果搜不到deny from all 就按照下面的方法来 ...
- 开始编写Makefile
1.Makefile 的编写规则一 目标列表:关联性列表 命令列表 目标列表:可以是多个以空格隔开多个目标文件 关联列表页称为先决条件:同样是用个或多个空格分开的目标文件 命令列表:用<tab& ...