std::array

template < class T, size_t N > class array;

Code Example

#include <iostream>
#include <array>
#include <cstring> using namespace std; int main(int argc, char **argv)
{
array<int, 5> intArr = {1,2,3,4,5};
for(auto it = intArr.begin(); it != intArr.end(); it++ )
{
cout << *it << "\t";
}
///< output: 1 2 3 4 5 cout << "\n";
///< r means reverse
for(auto rit = intArr.rbegin(); rit < intArr.rend(); rit++)
{
cout << *rit << "\t";
}
///< output: 5 4 3 2 1 cout << "\n";
///< c means const
for(auto cit = intArr.cbegin(); cit != intArr.cend(); cit++ )
{
cout << *cit << "\t";
}
///< output:1 2 3 4 5 cout << "\n";
for(auto crit = intArr.crbegin(); crit < intArr.crend(); crit++)
{
cout << *crit << "\t";
}
///< output:5 4 3 2 1 cout << "\n";
cout << "size of array:" << intArr.size() << "\n"; ///< output: 5
cout << "sizeof array:" << sizeof intArr << "\n"; ///< output: 5 cout << "\n";
array<char, 10> arrCh = {'a','b','c','d','e'};
cout << "size of array:" << arrCh.size() << "\n"; ///< output: 10
cout << "max_size of array" << arrCh.max_size() << "\n"; ///< output: 10 cout<< "\n";
array<int, 0> first;
array<int, 5> second;
cout << "first array:" << first.empty() << "\n";
///< output: 1, means true
cout << "second array:" << second.empty() << "\n";
///< output: 0, means false for(int i=0; i < second.size(); i++){
second[i]=i;
} for(auto it = second.begin(); it != second.end(); it++){
cout << *it << "\t";
}
///< output: 10 11 12 13 14 for(int i=0; i < second.size(); i++){
second.at(i) = i;
}
cout << "\n";
for(int i=0; i< second.size(); i++){
cout << second.at(i) << "\t";
}
///< output:1 2 3 4 5 array<int, 3> third = {1,2,3};
for(int &x:third){
cout << x << "\t";
}
///< output:1 2 3 cout << "\n";
cout << "array::front():" << third.front() << "\n"; ///< output: 1
cout << "array::back():" << third.back() << "\n"; ///< output: 3
cout <<"modify front and back\n";
third.front() == 11;
third.back() = 22;
cout << "array::front():" << third.front() << "\n"; ///< output: 11
cout << "array::back():" << third.back() << "\n"; ///< output: 22 const char * cstr = "Hello array";
array<char, 20> arrChar;
memcpy(arrChar.data(),cstr, strlen(cstr));
cout << arrChar.data() << "\n";
///< output: Hello array array<int,10> fourth;
fourth.fill(2);
for(int &x:fourth){
cout << x << "\t";
}
///< output: 2 2 2 2 2 2 2 2 2 2 array<int, 5> five = {1,2,3,4,5};
array<int, 5> six = {6,7,8,9,0};
five.swap(six);
cout << "\n";
for(int &x:five){
cout << x << "\t";
}
///< output: 6 7 8 9 0 cout << "\n";
for(int &x:six){
cout << x << "\t";
}
///< output:1 2 3 4 5 array<int,5> a = {1,2,3,4,5};
array<int,5> b = {1,2,3,4,5};
array<int,5> c = {5,4,3,2,1}; cout << "\n";
/** They are both true */
if( a == b ) cout << " a and b are equal!\n";
if( b!=c ) cout << "b and c are not equal!\n";
if( b < c ) cout << "b is less than c\n";
if( c > b ) cout << "c is greater than b\n";
if( a <= b ) cout << "a is less than or equal b\n";
if( a >= b ) cout << "ais greater than or equal b\n"; return 0;
}

Array class

Arrays are fixed-size sequence containers: they hold a specific number of elements ordered in a strict linear sequence.

Internally, an array does not keep any data other than the elements it contains (not even its size, which is a template parameter, fixed on compile time). It is as efficient in terms of storage size as an ordinary array declared with the language's bracket syntax ([]). This class merely adds a layer of member and global functions to it, so that arrays can be used as standard containers.

Unlike the other standard containers, arrays have a fixed size and do not manage the allocation of its elements through an allocator: they are an aggregate type encapsulating a fixed-size array of elements. Therefore,they cannot be expanded or contracted dynamically (see vector for a similar container that can be expanded).Zero-sized arrays are valid, but they should not be dereferenced (members front, back, and data).

Unlike with the other containers in the Standard Library, swapping two array containers is a linear operation that involves swapping all the elements in the ranges individually, which generally is a considerably less efficient

operation. On the other side, this allows the iterators to elements in both containers to keep their original container association.

Another unique feature of array containers is that they can be treated as tuple objects: The header overloads the get function to access the elements of the array as if it was a tuple, as well as specialized tuple_size

and tuple_element types.

Container properties

  • Sequence:Elements in sequence containers are ordered in a strict linear sequence.Individual elements are accessed by their position in this sequence.
  • Contiguous storage:The elements are stored in contiguous memory locations, allowing constant time random access to elements. Pointers to an element can be offset to access other elements.
  • Fixed-size aggregate:The container uses implicit constructors and destructors to allocate the required space statically. Its size is compile-time constant. No memory or time overhead.

Template parameters

  • T:Type of the elements contained. Aliased as member type array::value_type.
  • N:Size of the array, in terms of number of elements.

In the reference for the array member functions, these same names are assumed for the template parameters.

Member types

The following aliases are member types of array. They are widely used as parameter and return types by member functions:

member typedefinitio 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
const_reverse_iterator reverse_iterator<const_iterator>
size_type size_t unsigned integral type
difference_type ptrdiff_t

signed integral type

Member functions

Iterators
  • begin: Return iterator to beginning (public member function )
  • end: Return iterator to end (public member function )
  • rbegin: Return reverse iterator to reverse beginning (public member function )
  • rend: Return reverse iterator to reverse end (public member function )
  • cbegin: Return const_iterator to beginning (public member function )
  • cend: Return const_iterator to end (public member function )
  • crbegin: Return const_reverse_iterator to reverse beginning (public member function )
  • crend: Return const_reverse_iterator to reverse end (public member function )
Capacity
  • size: Return size (public member function )
  • max_size: Return maximum size (public member function )
  • empty: Test whether array is empty (public member function )
Element access
  • operator[]: Access element (public member function )
  • at: Access element (public member function )
  • front: Access first element (public member function )
  • back: Access last element (public member function )
  • data: Get pointer to data (public member function )
Modifiers
  • fill: Fill array with value (public member function )
  • swap: Swap content (public member function )
Non-member function overloads
  • get (array): Get element (tuple interface) (function template )
  • relational operators (array):Relational operators for array(function template )
Non-member class specializations
  • tuple_element: Tuple element type for array (class template specialization )
  • tuple_size: Tuple size traits for array (class template specialization )

参考文献

cplusplus


C++ std::array的更多相关文章

  1. c++编译错误C2971:"std::array":array_size:包含非静态存储不能用作废类型参数;参见“std::array”的声明

    在Qt5中这段代码编写有两种方式:一个编译成功,一个失败 成功版本: static constexpr size_t block_size = 0x2000;//8KB static constexp ...

  2. std::array中的std::get<n>()

    模板函数std::get<n>()是一个辅助函数,它能够获取到容器的第 n 个元素.模板参数的实参必须是一个在编译时可以确定的常量表达式,编译时会对它检查. get<n>()模 ...

  3. 将std::array转换成std::tuple

    template<typename Array, std::size_t... Index> decltype(auto) array2tuple_impl(const Array& ...

  4. std::array,std::vector,基于范围的for循环

    std::array除了有传统数组支持随机访问.效率高.存储大小固定等特点外,还支持迭代器访问.获取容量.获得原始指针等高级功能.而且它还不会退化成指针T *给开发人员造成困惑. for( 元素名变量 ...

  5. C++ Arrays, std::array, std::vector 总结

    原文来自: https://shendrick.net/Coding%20Tips/2015/03/15/cpparrayvsvector.html @Seth Hendrick Original a ...

  6. C++语言中std::array的神奇用法总结,你需要知道!

    摘要:在这篇文章里,将从各个角度介绍下std::array的用法,希望能带来一些启发. td::array是在C++11标准中增加的STL容器,它的设计目的是提供与原生数组类似的功能与性能.也正因此, ...

  7. C++ std::array 基本用法

    #include <iostream> #include <string> #include <array> using namespace std; // htt ...

  8. 源码阅读笔记 - 2 std::vector (2) 关于Allocator Aware Container特性

    所有的STL容器,都保存一个或默认,或由用户提供的allocator的实例,用来提供对象内存分配和构造的方法(除了std::array),这样的容器,被称作Allocator Aware Contai ...

  9. [翻译] C++ STL容器参考手册(第一章 <array>)

    返回总册 本章节原文:http://www.cplusplus.com/reference/array/array/ 1. std::array (C++11支持) template < cla ...

随机推荐

  1. webp图片实践之路

    最近,我们在项目中实践了webp图片,并且抽离出了工具模块,整合到了项目的基础模板中.传闻IOS10也将要支持webp,那么使用webp带来的性能提升将更加明显.估计在不久的将来,webp会成为标配. ...

  2. webpack入门教程之Hello webpack(一)

    webpack入门教程系列为官网Tutorials的个人译文,旨在给予想要学习webpack的小伙伴一个另外的途径.如有不当之处,请大家指出. 看完入门教程系列后,你将会学习到如下内容: 1.如何安装 ...

  3. 【WCF】自定义错误处理(IErrorHandler接口的用法)

    当被调用的服务操作发生异常时,可以直接把异常的原始内容传回给客户端.在WCF中,服务器传回客户端的异常,通常会使用 FaultException,该异常由这么几个东东组成: 1.Action:在服务调 ...

  4. RestTemplate发送请求并携带header信息

    1.使用restTemplate的postForObject方法 注:目前没有发现发送携带header信息的getForObject方法. HttpHeaders headers = new Http ...

  5. Angular2开发笔记

    Problem 使用依赖注入应该注意些什么 服务一般用来做什么 指令一般用来做什么 angular2如何提取公共组件 angular2为什么不需要提公共组件 父组件与子组件之间如何通讯 什么时候应该使 ...

  6. CentOS下mysql数据库常用命令总结

    mysql数据库使用总结 本文主要记录一些mysql日常使用的命令,供以后查询. 1.更改root密码 mysqladmin -uroot password 'yourpassword' 2.远程登陆 ...

  7. 在centos7上安装Jenkins

    在centos7上安装Jenkins 安装 添加yum repos,然后安装 sudo wget -O /etc/yum.repos.d/jenkins.repo http://pkg.jenkins ...

  8. 自己写的数据交换工具——从Oracle到Elasticsearch

    先说说需求的背景,由于业务数据都在Oracle数据库中,想要对它进行数据的分析会非常非常慢,用传统的数据仓库-->数据集市这种方式,集市层表会非常大,查询的时候如果再做一些group的操作,一个 ...

  9. 分享两个BPM配置小技巧

    1.小技巧 流程图修改后发布的话版本号会+1,修改次数多了之后可能会导致版本号很高,这个时候可以将流程导出,然后删除对应的流程包再导入,发布数据模型和流程图之后,版本清零 2.小技巧 有的同事入职后使 ...

  10. Greenplum 的分布式框架结构

    Greenplum 的分布式框架结构 1.基本架构 Greenplum(以下简称 GPDB)是一款典型的 Shared-Nothing 分布式数据库系统.GPDB 拥有一个中控节点( Master ) ...