C++Primer 第九章
//1.vector:可变大小数组。支持快速随机访问,在尾部之外的位置插入或删除元素可能很慢。注意点:不要在vector中存放bool类型,vector<bool>并不是一个容器,其实现方式类似于位域,不能对其元素取地址或者建立引用,因为其元素仅仅是一个比特。然而deque<bool>却是一个容器。
// deque:双端队列。支持快速随机访问,在头尾插入或删除元素很快。
// list:双向链表。只支持双向顺序访问。任何位置插入或删除元素都很快。
// forward_list:单向链表。只支持单向顺序访问。在任何位置插入或删除元素都很快。
// string:与vector相似的容器,专门用于保存字符。支持随机访问。在尾部插入或删除元素很快。 //2.通常情况选择vector,当不确定用哪种容器的时候,那么就只使用迭代器操作,这样在更换容器的时候会很方便。 //3.如果容器元素类型没有默认构造函数,当为此容器提供了大小参数外,还必须提供一个显示的元素初始值(这个显示的元素初始值必须能被构造成容器的元素类型)。
class CTest
{
public:
CTest(int i) : value(i){}
private:
int value;
}; vector<CTest> vecTest(2, 10); //vecTest = [2]({value=10 },{value=10 })
vector<CTest> vecTest1(2); //错误,没有传入初始值
vector<CTest> vecTest2; //正确 //4.公用容器的类型别名操作:
// iterator:此容器的迭代器类型
// const_iterator:只读迭代器类型
// size_type:无符号整形,足够保存此种容器类型最大可能容器的大小。32位程序下,为4字节,64位程序下为8字节。
// difference_type:带符号整形,足够保存两个迭代器之间的距离。32位程序下,为4字节,64位程序下为8字节。在32位下应用程序可使用的内存小于2G,也就是小于int的最大值。
// value_type:容器所存元素类型。
// reference:容器所存元素的引用类型。等价于value_type&
// const_reference:容器所存元素的常量引用类型。等价于const value_type& //5.反向迭代器与正向迭代器相比,各种操作的含义均发生颠倒。例如++会得到反向迭代器的上一个元素。 //6.可以将A容器中的元素拷贝到B容器中,只要A容器的元素类型能转换为B容器的元素类型
list<double> listDouble;
listDouble.emplace_back(1.1);
listDouble.emplace_back(2.2);
vector<int> vecInt(listDouble.begin(), listDouble.end()); //vecInt = [2](1,2)
vector<int> vecInt1;
vecInt1.assign(listDouble.begin(), listDouble.end()); //vecInt1 = [2](1,2)
// 注意点:容器的assign操作还有一种用法:vecInt1.assign(2,1); //vecInt1 = [2](1,1) //7.当改变了容器的元素后,注意指向容器元素的迭代器、指针、引用可能会失效。比如容器的赋值操作就会导致上述结果。在每次改变容器的操作后都应该重新定位迭代器、指针、引用。 //8.容器的emplace系列的函数,使用给定的参数创建一个元素(如果不是内置类型则调用其构造函数),而push_back或者push_front函数则是按值拷贝一个元素(不会主动调用元素的构造函数)。insert在这方面的表现和push_back系列函数一致。
vector<unique_ptr<char[]>> vecStr;
vecStr.emplace_back(new char[10]()); //合法
vecStr.push_back(new char[10]()); //非法
vecStr.insert(vecStr.begin(), new char[10]()); //vs2010下虽然合法,但是从语法上来说,这句话是错误的。
#include <vector>
using std::vector;
class CTest
{
public:
explicit CTest(int value)
{
value0 = value;
printf("0 ");
}
CTest(const CTest& Test)
{
value0 = Test.value0;
printf("1 ");
}
private:
int value0;
};
int _tmain(int argc, _TCHAR* argv[])
{
vector<CTest> vecTest(1, CTest(0));//输出0 1 这是先进行构造然后将其拷贝进vector
CTest Test(3); //输出0
vecTest.push_back(Test); //输出1 1 这是先拷贝构造然后将其拷贝进vector
//vecTest.push_back(1); //由于构造函数是explicit的,所以这句话非法
vecTest.emplace_back(2); //输出1 1 0 前面两个1是因为vector发生内存重新分配,所以拷贝了原先的2个元素,最后一个0是直接构造
printf("s");
//由上述代码得出结论,emplace系列函数比push系列函数的效率,在理论上高点
}
//9.容器中不能存放元素的引用。 //10.一般容器都提供了front()和back()成员函数,分别用于返回首尾元素的引用。一般容器提供了at()成员函数,用法类似于下标运算符,但是前者多了判断下标是否越界的功能,若越界则会抛出out_of_range异常。 //11.单向链表forward_list的插入和删除操作:insert_after,emplace_after,erase_after。由于单向链表可以方便的得到其下一个成员而无法得到其上一个成员,所以其插入和删除操作不同于其他容器,相应的before_begin返回单向链表的首前迭代器。 //12.利用resize成员函数可以很方便的改变容器的大小,支持为要新添加的元素传入初始化参数。
// 利用reserve成员函,来分配至少能容纳指定个元素的内存空间。注意点:这里仅是内存分配而不涉及元素构造,此函数不会改变容器的size,但是会改变容器的capacity。 //13.string类的常用操作:
// c_str():返回const char*类型的字符串
// substr:从指定的string中的指定位置返回指定长度的string
// find:查找指定序列在指定位置后第一次出现的位置
// rfind:查找指定序列在指定位置后最后一次出现的位置
// find_first_of:查找指定序列在指定位置后第一次出现序列中的元素的位置
// find_last_of:查找指定序列在指定位置后最后一次出现序列中的元素的位置
// find_first_not_of:在指定位置后查找第一个不在指定序列中的元素的位置
// find_last_not_of:在指定位置后查找最后一个不在指定序列中的元素的位置
// replace:将指定的序列中的元素替换为另一个指定序列中的元素 //14.容器适配器:一个容器适配器能接受一种已有的容器类型,使其行为看起来像一种不同的类型。
// stack:定义在头文件stack中,在栈顶进行操作。
// 支持操作:pop(),push(),emplace(),top()
// 默认使用deque实现,也可以在list或者vector之上实现。
// queue:定义在头文件queue中,其元素为先进先出。进入的元素放置在队尾,在队首进行删除。
// 支持操作:pop(),front(),back(),push(),emplace()
// 默认使用deque实现,可以用list和vector实现。
// priority_queue:定义在头文件queue中。允许我们为队列中的元素建立优先级。默认使用<来确定相对优先级(由大到小排列)。
// 支持操作:pop(),push(),emplace(),top()。注意:top()返回priority_queue中优先级最高的元素。支持随机访问。
// 默认使用vector实现,也可以用deque实现
stack<int, vector<int>> staInt; //使用非默认容器来构造容器适配器。 //15.
// begin(),end() ++ ->
// begin() end()
// | |
// v v
// AAAAAAAAAAAAAAAAA
// ^ ^
// | |
// rend() rbegin()
// rend(), rbegin() -- ->
C++Primer 第九章的更多相关文章
- C++ Primer : 第九章 : vector变长、string的其他操作以及容器适配器
vector变长机制.string的其他构造方法,添加.替换和搜索操作,string比较和数值转换,最后是容器适配器. vector对象是如何增长的 vector和string类型提供了一些成员函数, ...
- C++ Primer 第九章 顺序容器
由于书籍上写的已经很经典了,故大部分用图片的形式来阐述概念,代码纯手打进行验证. 1.顺序容器类型:vector.deque.list.forword_list.array.string. 2.顺序容 ...
- C++ Primer : 第九章 : 顺序容器的操作以及迭代器失效问题
顺序容器的添加.访问.删除操作以及forward_list的特殊操作,还有迭代器失效问题. 一.向容器添加元素 // array不支持这些操作 // forward_list有自己撰于的版本的inse ...
- C++ Primer : 第九章 : 顺序容器的定义、迭代器以及赋值与swap
顺序容器属于C++ STL的一部分,也是非常重要的一部分. 顺序容器包括: std::vector,包含在头文件<vector>中 std::string, 包含在头文件<strin ...
- C++ Primer第九章课后编程问题
1. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZ3V1Z2xlMjAxMA==/font/5a6L5L2T/fontsize/400/fill/I0J ...
- C++ Primer Plus学习:第九章
C++第九章:内存模型与名称空间 C++在内存中存储数据方面提供了多种选择.可直接选择保留在内存中的时间长度(存储持续性)以及程序哪一部分可以访问数据(作用域和链接)等. 单独编译 程序分为三个部分: ...
- 【C++】《C++ Primer 》第九章
第九章 顺序容器 一.顺序容器概述 顺序容器(sequential container):为程序员提供了控制元素存储和访问顺序的能力.这种顺序不依赖于元素的值,而是与元素加入容器时的位置相对应. 不同 ...
- 精通Web Analytics 2.0 (11) 第九章: 新兴分析—社交,移动和视频
精通Web Analytics 2.0 : 用户中心科学与在线统计艺术 第九章: 新兴分析-社交,移动和视频 网络在过去几年中发生了不可思议的发展变化:从单向对话到双向对话的转变; 由视频,Ajax和 ...
- 第九章:四大组件之Broadcast Receiver
第九章:四大组件之Broadcast Receiver 一.广播的功能和特征 广播的生命周期很短,经过调用对象-->实现onReceive-->结束,整个过程就结束了.从实现的复杂度和 ...
随机推荐
- flex的Accordion组件头部文本居中显示
flex的Accordion组件头部文本默认是居左的,可以通过设置headerStyleName属性使之居中,另外还可以设置字体的样式等 <?xml version="1.0" ...
- 自用有线IP切换
@echo ※※※※※※※※※※※※※※※※※※※※※※※※※※※※ @echo ※ ※ @echo ※ 本命令用于设置外网视频与内网打印切换IP地址 ※ @echo ※ ※ @echo ※ ※ @e ...
- locality
Computer Systems A Programmer's Perspective Second Edition Well-written computer programs tend to ex ...
- 挑战编程PC/UVa Stern-Brocot代数系统
/* Stern-Brocot代数系统 Stern-Brocot树是一种生成所有非负的最简分数m/n的美妙方式. 其基本方式是从(0/1, 1/0)这两个分数开始, 根据需要反复执行如下操作: 在相邻 ...
- Python - 求斐波那契数列前N项之和
n = int(input("Input N: ")) a = 0 b = 1 sum = 0 for i in range(n): sum += a a, b = b, a + ...
- 【java】由equals和==的区别引出的常量池知识
equals和==的区别,百度查到的结果大都是:equals比较的是值,==比较的是引用地址. String str1 = "abc"; String str2 = "a ...
- //四舍五入//得到倒序//比较字符串//拦截时间,实现超时锁屏//判断是否越狱//配置PodFile//Storyboard中跳转操作//处理不可逆的push界面操作
//处理不可逆的push界面操作 VerifyRealNameViewController *verifyRealNameCtrl = [VerifyRealNameViewController vi ...
- SVN提交注意点
一.提交之前先更新 1. SVN更新的原则是要随时更新,随时提交.当完成了一个小功能,能够通过编译并且自己测试之后,谨慎地提交. 2. 如果在修改的期间别人也更改了sv ...
- oracle 表查询一
通过scott用户下的表来演示如何使用select语句,接下来对emp.dept.salgrade表结构进行解说. emp 雇员表字段名称 数据类型 是否为空 备注-------- ...
- threading多线程
什么是线程? 线程是操作系统能够进行运算调度的最小单位.它被包含在进程之中,是进程中的实际运作单位.一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务.一 ...