[翻译] C++ STL容器参考手册(第一章 <array>)
本章节原文:http://www.cplusplus.com/reference/array/array/
1. std::array (C++11支持)
template < class T, size_t N > class array;
数组类
数组容器是固定长度的序列容器:按照严格的线性顺序,存储一定数量的元素。
数组容器内部并不维护除了元素本身之外的任何数据(甚至不保存自己的size,这是一个编译时就确定的模板参数)。数组容器对存储空间的利用效率和普通数组一样高。数组类仅仅在数组之外增加了一些成员以及全局函数,使得这些数组能够被当作一个标准容器来使用。
与其他的标准容器不同的是,数组容器具有固定的大小,并且不使用allocator来管理对元素内存空间的分配,数组容器集合了各样的成员并且封装了一个固定长度的数组。因此数组容器不能够被动态的扩展或者截断(参考vector,这是一个能够被扩展的相似的容器)。
定义长度为0的数组容器是合法的,但是不能对它解引用*(成员front,back,以及data)。
*译者:解引用是引用的反向操作,如下例:
int a=;
int* pa=&a; //此处的&a是引用操作
*pa=; //此处的*pa是解引用操作
与标准库中得其它容器不同的还有,交换*两个数组容器的操作涉及到逐个交换容器中每一个元素,通常情况下这是一个非常低效的操作。从另一方面来讲,这样的实现使得他们的迭代器始终保持着与原容器的关联。
*译者:交换操作是数组容器提供的一个方法(函数),通过这个方法可以交换两个数组容器内的元素,见swap。
数组容器另外一个独特的特性是它可以被当做一个tuple对象来操作:<array>头文件中重载了get函数,通过它可以像tuple一样来访问数组容器的元素,同样的也可以使用tuple_size以及tuple_element来获取数组容器的大小与元素类型。
2. 容器属性
- 序列
- 序列容器中的元素是按照严格的线性顺序来存储的。访问每一个元素时,都是通过这个元素在序列中所处的位置来访问的。
- 连续的存储空间
- 序列容器中的元素是存储在一片连续的内存空间中,因此随机访问任意元素的时间都是相同的。指向一个元素的指针可以通过偏移地址来访问其它元素。
- 固定长度
- 容器使用构造器与析构器来静态分配所需要的空间。容器的大小在编译时就已经确定。(运行时)没有(额外的)空间或时间上的开销。
3. 模板参数
- 参数T
- 容器所包含元素的类型。与类成员array::value_type是一致的。
- 参数N
- 数组容器的大小,表示元素的数量。
- 在array成员函数的参考或说明中,这些参数名默认作为模板参数*。
- *译者:比如说这里template < class T, size_t N > class array;
4. 成员类型
- 以下的这些别名都是array的成员类型。他们被广泛的用作参数类型和成员函数返回值的类型。
member type | definition | notes |
---|---|---|
value_type | The first template parameter (T) | |
reference | value_type& | |
const_reference | const value_type& | |
pointer | value_type* | |
const_pointer | const value_type* | |
iterator | a random access iterator to value_type | convertible to const_iterator |
const_iterator | a random access iterator to const value_type | |
reverse_iterator | reverse_iterator<iterator> | |
const_reverse_iterator | reverse_iterator<const_iterator> | |
size_type | size_t | unsigned integral type |
difference_type | ptrdiff_t | signed integral type |
5. 成员函数
迭代器
- begin
- 返回指向容器最前端的迭代器 (公有成员函数)
- end
- 返回指向容器最后端的迭代器 (公有成员函数)
- rbegin
- 返回指向容器最后端的反向迭代器 (公有成员函数)
- rend
- 返回指向容器最前端的反向迭代器 (公有成员函数)
- cbegin
- 返回指向容器最前端的只读迭代器 (公有成员函数)
- cend
- 返回指向容器最后端的只读迭代器 (公有成员函数)
- crbegin
- 返回指向容器最后端的反向只读迭代器 (公有成员函数)
- crend
- 返回指向容器最前端的反向只读迭代器 (公有成员函数)
- *译者:这里的“最前端”与“最后端”分别指容器中第一个元素与容器中最后一个元素。只读迭代器本身可以进行增减操作,但是使用只读迭代器指向的元素是只读的。
容量
- size
- 返回元素的数量 (公有成员函数)
- max_size
- 返回容器最多能够存储的元素数量 (公有成员函数)
- empty
- 测试数组容器是否为空 (公有成员函数)
元素的访问
- operator[]
- 访问元素 (公有成员函数)
- at
- 访问元素 (公有成员函数)
- front
- 访问第一个元素 (公有成员函数)
- back
- 访问最后一个元素 (公有成员函数)
- data
- 返回指向数据的指针* (公有成员函数)
- *译者:data返回的指针其实就是指向第一个元素的指针。
修改器
- fill
- 使用某个值填充整个容器 (公有成员函数)
- swap
- 交换容器的内容 (公有成员函数)
6. 重载的非成员函数
- get (array)
- 获取元素(元组接口)(模板函数)
数组容器的关系运算符(模板函数)
7. 特化非成员类
数组类型的元组元素(类模板的特化)
数组类型的元组长度特性(类模板的特化)
[翻译] C++ STL容器参考手册(第一章 <array>)的更多相关文章
- [翻译] C++ STL容器参考手册 (总册)
1. 写在最前面 这将是博主的第一篇技术博客,思考再三决定从翻译开始.这将是一个系列的博客,由不同的章节组成,章节之间由超链接联系,开发过程将使用增量式开发,每次完成一个章节.本篇是本系列的总册,提供 ...
- [翻译] C++ STL容器参考手册(第二章 <deque>)
返回总册 本章节原文:http://www.cplusplus.com/reference/deque/deque/ 1. std::deque template < class T, clas ...
- [书籍翻译] 《JavaScript并发编程》第一章 JavaScript并发简介
> 本文是我翻译<JavaScript Concurrency>书籍的第一章,该书主要以Promises.Generator.Web workers等技术来讲解JavaScript并 ...
- Linux/Unix系统编程手册 第一章:历史和标准
Unix的开发不受控于某一个厂商或者组织,是由诸多商业和非商业团体共同贡献进行演化的.这导致两个结果:一是Unix集多种特性于一身,二是由于参与者众多,随着时间推移,Unix实现方式逐渐趋于分裂. 由 ...
- 【翻译】Express web应用开发 第一章
本章节是一个对初学者友好的Express介绍.你将学习到Express的基础知识.核心概念和实现一个Express应用的组成部分.现阶段我们不需要做太多的编码,本章节会让你熟悉和习惯Express,为 ...
- Oauth2手册 第一章
来源:https://github.com/jeansfish/RFC6749.zh-cn/blob/master/SUMMARY.md 1. 简介在传统的客户端-服务器身份验证模式中,客户端请求服务 ...
- essential c++ 第一章 array及vector相关使用
将对象初始化: 1.用等号(=)赋值运算符初始化,针对对象是内置类型或者对象可以单一值初始化 2.构造函数初始化,针对对象需要多个初始值的情况 单括号括住的字符表示字符常量(‘ ’): 第一个反斜线表 ...
- Lua 5.2 中文参考手册
闲来无事,发现Lua更新到了5.2.2,参考手册也更到了5.2,在网上发现只有云风翻译的5.1版,花了几天时间翻译了一些. 参考手册有点长,又要随时修改,所以在github上建了项目,有需要的朋友可以 ...
- Spring Security 5.0.x 参考手册 【翻译自官方GIT-2018.06.12】
源码请移步至:https://github.com/aquariuspj/spring-security/tree/translator/docs/manual/src/docs/asciidoc 版 ...
随机推荐
- JavaScript中的一些细节
1.设置id / class等属性 用 setAttribute 设置一些常规属性如 id ,className 的时候经常不起作用,只能用 object.id = value 这样来设置 news_ ...
- 设置ubuntu Android sdk环境变量
cd /etc/ sudo gedit profile 在后面把tools和platform-tools的路径追加进去即可 PATH=$PATH:/home/android_sdk/tools 然后再 ...
- 制作 leanote docker 镜像
leanote 使用 mongodb 存储数据,如果把 mongodb 单独做成一个镜像,初始化数据时比较麻烦,所以最后还是决定把 mongodb 和 leanote 放到同一个镜像里边. docke ...
- 在子jsp页面中调用父jsp中的function或父jsp调用子页面中的function
项目场景: A.jsp中有一个window,window里嵌入了一个<iframe>,通过<iframe>引入了另一个页面B.jsp.在B.jsp中的一个function中需要 ...
- memcached的安装
最近在研究怎么让Discuz!去应用Memcache去做一些事情,记录下Memcache安装的过程. Linux下Memcache服务器端的安装 服务器端主要是安装memcache服务器端,目前的最新 ...
- spark提交任务的流程
1.spark提交流程 sparkContext其实是与一个集群建立一个链接,当你停掉它之后 就会和集群断开链接,则属于这个资源的Excutor就会释放掉了,Driver 向Master申请资源,Ma ...
- 完美解决ListView 与 ScrollView 共存问题
1:首先设置ListView的高度,在setAdapter之后调用此方法. public static void setListViewHeightBasedOnChildren(ListView l ...
- poj2409 Let it Bead
Let it Bead Time Limit: 1000MS M ...
- 数据结构之顺序表,c#实现
using System; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using S ...
- LLVM安装
cd ~tar -vzxf llvm-3.3.src.tar.gzmv llvm-3.3.src llvmcd llvm/tools/tar -vzxf cfe-3.3.src.tar.gzmv cf ...