GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages
std::array(3) C++ Standard Libary std::array(3)

std::array - std::array


Defined in header <array>
template<


class T, (since C++11)
std::size_t N


> struct array;


std::array is a container that encapsulates fixed size arrays.


This container is an aggregate type with the same semantics as a struct holding a
C-style array T[N] as its only non-static data member. Unlike a C-style array, it
doesn't decay to T* automatically. As an aggregate type, it can be initialized with
aggregate-initialization given at most N initializers that are convertible to T:
std::array<int, 3> a = {1,2,3};.


The struct combines the performance and accessibility of a C-style array with the
benefits of a standard container, such as knowing its own size, supporting
assignment, random access iterators, etc.


std::array satisfies the requirements of Container and ReversibleContainer except
that default-constructed array is not empty and that the complexity of swapping is
linear,
satisfies the requirements of ContiguousContainer,
(since C++17) and partially satisfies the requirements of SequenceContainer.


There is a special case for a zero-length array (N == 0). In that case,
array.begin() == array.end(), which is some unique value. The effect of calling
front() or back() on a zero-sized array is undefined.


An array can also be used as a tuple of N elements of the same type.


Iterator invalidation


As a rule, iterators to an array are never invalidated throughout the lifetime of
the array. One should take note, however, that during swap, the iterator will
continue to point to the same array element, and will thus change its value.


Member type Definition
value_type T
size_type std::size_t
difference_type std::ptrdiff_t
reference value_type&
const_reference const value_type&
pointer value_type*
const_pointer const value_type*
LegacyRandomAccessIterator and (until C++17)
LegacyContiguousIterator to value_type
LegacyRandomAccessIterator and (since C++17)
iterator LegacyContiguousIterator that is a LiteralType (until C++20)
to value_type
LegacyRandomAccessIterator,
contiguous_iterator, and ConstexprIterator to (since C++20)
value_type
LegacyRandomAccessIterator and (until C++17)
LegacyContiguousIterator to const value_type
LegacyRandomAccessIterator and (since C++17)
const_iterator LegacyContiguousIterator that is a LiteralType (until C++20)
to const value_type
LegacyRandomAccessIterator,
contiguous_iterator, and ConstexprIterator to (since C++20)
const value_type
reverse_iterator std::reverse_iterator<iterator>
const_reverse_iterator std::reverse_iterator<const_iterator>


initializes the array following the rules of aggregate
constructor initialization (note that default initialization may result in
(implicitly declared) indeterminate values for non-class T)
(public member function)
destructor destroys every element of the array
(implicitly declared) (public member function)
operator= overwrites every element of the array with the corresponding
(implicitly declared) element of another array
(public member function)


at access specified element with bounds checking
(C++11) (public member function)
operator[] access specified element
(C++11) (public member function)
front access the first element
(C++11) (public member function)
back access the last element
(C++11) (public member function)
data direct access to the underlying array
(C++11) (public member function)


begin returns an iterator to the beginning
cbegin (public member function)
(C++11)
end returns an iterator to the end
cend (public member function)
(C++11)
rbegin returns a reverse iterator to the beginning
crbegin (public member function)
(C++11)
rend returns a reverse iterator to the end
crend (public member function)
(C++11)


empty checks whether the container is empty
(C++11) (public member function)
size returns the number of elements
(C++11) (public member function)
max_size returns the maximum possible number of elements
(C++11) (public member function)


fill fill the container with specified value
(C++11) (public member function)
swap swaps the contents
(C++11) (public member function)


operator==
operator!=
operator<
operator<=
operator>
operator>= lexicographically compares the values in the array
operator<=> (function template)
(removed in C++20)
(removed in C++20)
(removed in C++20)
(removed in C++20)
(removed in C++20)
(C++20)
std::get(std::array) accesses an element of an array
(C++11) (function template)
std::swap(std::array) specializes the std::swap algorithm
(C++11) (function template)
to_array creates a std::array object from a built-in array
(C++20) (function template)


std::tuple_size<std::array> obtains the size of an array
(C++11) (class template specialization)
std::tuple_element<std::array> obtains the type of the elements of array
(C++11) (class template specialization)


Deduction guides(since C++17)

// Run this code


#include <string>
#include <iterator>
#include <iostream>
#include <algorithm>
#include <array>


int main()
{
// construction uses aggregate initialization
std::array<int, 3> a1{ {1, 2, 3} }; // double-braces required in C++11 prior to
// the CWG 1270 revision (not needed in C++11
// after the revision and in C++14 and beyond)


std::array<int, 3> a2 = {1, 2, 3}; // double braces never required after =


std::array<std::string, 2> a3 = { std::string("a"), "b" };


// container operations are supported
std::sort(a1.begin(), a1.end());
std::reverse_copy(a2.begin(), a2.end(),
std::ostream_iterator<int>(std::cout, " "));


std::cout << '\n';


// ranged for loop is supported
for(const auto& s: a3)
std::cout << s << ' ';


// deduction guide for array creation (since C++17)
[[maybe_unused]] std::array a4{3.0, 1.0, 4.0}; // -> std::array<double, 3>
}


3 2 1
a b


make_array Creates a std::array object whose size and optionally
(library fundamentals TS v2) element type are deduced from the arguments
(function template)

2022.07.31 http://cppreference.com

Search for    or go to Top of page |  Section 3 |  Main Index

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with ManDoc.