Array (C++): Difference between revisions
grammar |
m more grammar fixes |
||
Line 1: | Line 1: | ||
{{lowercase}} |
{{lowercase}} |
||
The '''array''' is a wrapper [[Class (computer programming)|class]] that provides an [[Standard Template Library|STL]]-like interface to standard fixed-size [[C (programming language)|C]] arrays. It also overcomes several limitations of standard |
The '''array''' is a wrapper [[Class (computer programming)|class]] that provides an [[Standard Template Library|STL]]-like interface to standard fixed-size [[C (programming language)|C]] arrays. It also overcomes several limitations of standard arrays. |
||
== Creation history == |
== Creation history == |
||
Line 12: | Line 12: | ||
Standard C arrays have several principal limitations: |
Standard C arrays have several principal limitations: |
||
* They aren't [[value type]]s. They can not be copied like |
* They aren't [[value type]]s. They can not be copied like other objects. |
||
* They do not provide an STL-like interface. |
* They do not provide an STL-like interface. |
||
== Design == |
== Design == |
||
The <tt>array</tt> template class is defined in header <tt><array></tt> in the C++ standard library and in header <tt><boost/array.hpp></tt> in boost. It can reside in namespaces <tt>std::</tt> (in [[C++0x]]), <tt>std::tr1::</tt> (in C++03 with TR1) or <tt>boost::</tt>. |
|||
The <tt>array</tt> class template is parametrized with |
The <tt>array</tt> class template is parametrized with the type of the elements and the number of elements. It can be instantiated with any type that fulfills the <tt>CopyConstructible</tt> and <tt>Assignable</tt> requirements. It also itself fulfills <tt>CopyConstructible</tt> and <tt>Assignable</tt> requirements. |
||
If <tt>array</tt> class template is instantiated with a type that fulfills <tt>EqualityComparable</tt> or <tt>LessThanComparable</tt> requirements, it fulfills <tt>EqualityComparable</tt> or <tt>LessThanComparable</tt> correspondingly. |
If <tt>array</tt> class template is instantiated with a type that fulfills <tt>EqualityComparable</tt> or <tt>LessThanComparable</tt> requirements, it fulfills <tt>EqualityComparable</tt> or <tt>LessThanComparable</tt> correspondingly. |
||
Line 27: | Line 27: | ||
=== Implementation as aggregate === |
=== Implementation as aggregate === |
||
<tt>array</tt> class is implemented as an aggregate class. This allows an array to be initialized with a brace- |
The <tt>array</tt> class is implemented as an aggregate class. This allows an array to be initialized with a brace-enclosed, comma-separated list of initializers for the elements of the container, written in increasing subscript order: |
||
<source lang="cpp"> |
<source lang="cpp"> |
||
Line 33: | Line 33: | ||
</source> |
</source> |
||
Note that if there are fewer elements in the initializer list, then each remaining element gets default-initialized ( |
Note that if there are fewer elements in the initializer list, then each remaining element gets default-initialized. (Thus, it has a defined value.) |
||
However, this approach has its drawbacks: |
However, this approach has its own drawbacks: Passing no initializer list means that the elements have an indeterminate initial value, because the rule says that aggregates may have: |
||
* No user-declared constructors. |
* No user-declared constructors. |
||
Line 42: | Line 42: | ||
* No virtual functions. |
* No virtual functions. |
||
Note that for standard conforming compilers it is possible to use fewer braces (according to 8.5.1 (11) of the Standard). That is, array can be initialized as follows: |
Note that for standard conforming compilers it is possible to use fewer braces (according to 8.5.1 (11) of the Standard). That is, the <tt>array</tt> template can be initialized as follows: |
||
<source lang="cpp"> |
<source lang="cpp"> |
||
Line 50: | Line 50: | ||
== Differences from standard array == |
== Differences from standard array == |
||
* <tt>array</tt> class is a value type. It satisfies <tt>CopyConstructable</tt> and <tt>Assignable</tt> requirements. |
* The <tt>array</tt> class is a value type. It satisfies <tt>CopyConstructable</tt> and <tt>Assignable</tt> requirements. |
||
* <tt>array</tt> class can not be implicitly cast to <tt>T *</tt> or <tt>T const *</tt>. However there is member function <tt>data()</tt> that returns a pointer to first element. |
* The <tt>array</tt> class can not be implicitly cast to <tt>T *</tt> or <tt>T const *</tt>. However there is member function <tt>data()</tt> that returns a pointer to the first element. |
||
* <tt>array</tt> implementation is not required to do bound check. However implementation in boost |
* The <tt>array</tt> implementation is not required to do bound check. However the implementation in boost does that for <tt>operator[]</tt>, but not for iterators. |
||
=== Zero-sized arrays === |
=== Zero-sized arrays === |
||
Unlike standard arrays, <tt>array</tt> class can have |
Unlike standard arrays, the <tt>array</tt> class can have size zero. The effect of calling <tt>front()</tt> or <tt>back()</tt> for a zero-sized <tt>array</tt> is implementation-defined, but <tt>begin()</tt> and <tt>end()</tt> shall return the same unique value. The return value of <tt>data()</tt> is unspecified for zero-sized <tt>array</tt>s. |
||
== Differences from standard containers == |
== Differences from standard containers == |
||
* <tt>array</tt> class does not provide constant-time swap. Instead it provides linear-time swap. |
* The <tt>array</tt> class does not provide constant-time swap. Instead it provides linear-time swap. |
||
* Because <tt>array</tt> class is aggregate it does not provide fill and range constructors. Its default constructor also does not initialize elements with zeros. |
* Because the <tt>array</tt> class is an aggregate it does not provide fill and range constructors. Its default constructor also does not initialize elements with zeros. |
||
* size() is always constant, based on the second template argument of the type. |
* <tt>size()</tt> is always constant, based on the second template argument of the type. |
||
* The container provides no allocator support. |
* The container provides no allocator support. |
||
== Overview of functions == |
== Overview of functions == |
||
An object of |
An object of class <tt>array</tt> can be created using default constructor, copy constructor or initializer list syntax. |
||
{| class="wikitable" style="text-align: center"| |
{| class="wikitable" style="text-align: center"| |
||
Line 82: | Line 82: | ||
|} |
|} |
||
The <tt>array</tt> class provides a swap function and the assignment operator. The only difference from other containers is that <tt>swap</tt> takes linear time. |
|||
{| class="wikitable" style="text-align: center"| |
{| class="wikitable" style="text-align: center"| |
||
Line 96: | Line 96: | ||
|} |
|} |
||
Although TR1 define function <tt>assign</tt> to fill array with specified value, [[C++0x]] has function <tt>fill</tt> |
Although TR1 define function <tt>assign</tt> to fill an array with a specified value, [[C++0x]] has the function <tt>fill</tt> for the same purpose. The boost implementation of <tt>array</tt> supports both functions. |
||
{| class="wikitable" style="text-align: center"| |
{| class="wikitable" style="text-align: center"| |
||
Line 110: | Line 110: | ||
|} |
|} |
||
The <tt>array</tt> class provides a standard iterator interface. |
|||
{| class="wikitable" style="text-align: center"| |
{| class="wikitable" style="text-align: center"| |
||
Line 128: | Line 128: | ||
|} |
|} |
||
The <tt>array</tt> class provides standard query-capacity functions. |
|||
{| class="wikitable" style="text-align: center"| |
{| class="wikitable" style="text-align: center"| |
||
Line 144: | Line 144: | ||
|} |
|} |
||
The <tt>array</tt> class provides a standard set of element access functions. |
|||
{| class="wikitable" style="text-align: center"| |
{| class="wikitable" style="text-align: center"| |
||
Line 162: | Line 162: | ||
|} |
|} |
||
The <tt>array</tt> class has six standard comparison operators. |
|||
{| class="wikitable" style="text-align: center"| |
{| class="wikitable" style="text-align: center"| |
||
Line 198: | Line 198: | ||
|} |
|} |
||
The <tt>array</tt> class provides the standard tuple interface. |
|||
{| class="wikitable" style="text-align: center"| |
{| class="wikitable" style="text-align: center"| |
||
Line 213: | Line 213: | ||
|} |
|} |
||
The <tt>array</tt> class provides the standard set of dependent types. |
|||
{| class="wikitable" style="text-align: center"| |
{| class="wikitable" style="text-align: center"| |
Revision as of 21:10, 27 April 2011
The array is a wrapper class that provides an STL-like interface to standard fixed-size C arrays. It also overcomes several limitations of standard arrays.
Creation history
In his book Generic Programming and the STL, Matthew H. Austern introduces a wrapper class for ordinary arrays with static size, called block. It is safer and has no worse performance than ordinary arrays. In The C++ Programming Language, 3rd edition, Bjarne Stroustrup introduces a similar class, called c_array, which Nicolai Josuttis presents slightly modified in his book The C++ Standard Library - A Tutorial and Reference, called carray.
Under the name array this class is introduced in boost libraries by Nicolai Josuttis. Later this class was introduced in the C++ Standard Library in TR1.
Motivation
Standard C arrays have several principal limitations:
- They aren't value types. They can not be copied like other objects.
- They do not provide an STL-like interface.
Design
The array template class is defined in header <array> in the C++ standard library and in header <boost/array.hpp> in boost. It can reside in namespaces std:: (in C++0x), std::tr1:: (in C++03 with TR1) or boost::.
The array class template is parametrized with the type of the elements and the number of elements. It can be instantiated with any type that fulfills the CopyConstructible and Assignable requirements. It also itself fulfills CopyConstructible and Assignable requirements.
If array class template is instantiated with a type that fulfills EqualityComparable or LessThanComparable requirements, it fulfills EqualityComparable or LessThanComparable correspondingly.
Class also provides standard iterators and element access functions.
Implementation as aggregate
The array class is implemented as an aggregate class. This allows an array to be initialized with a brace-enclosed, comma-separated list of initializers for the elements of the container, written in increasing subscript order:
array<int, 4> a = { { 1, 2, 3 } };
Note that if there are fewer elements in the initializer list, then each remaining element gets default-initialized. (Thus, it has a defined value.)
However, this approach has its own drawbacks: Passing no initializer list means that the elements have an indeterminate initial value, because the rule says that aggregates may have:
- No user-declared constructors.
- No private or protected non-static data members.
- No base classes.
- No virtual functions.
Note that for standard conforming compilers it is possible to use fewer braces (according to 8.5.1 (11) of the Standard). That is, the array template can be initialized as follows:
array<int, 4> a = { 1, 2, 3 };
Differences from standard array
- The array class is a value type. It satisfies CopyConstructable and Assignable requirements.
- The array class can not be implicitly cast to T * or T const *. However there is member function data() that returns a pointer to the first element.
- The array implementation is not required to do bound check. However the implementation in boost does that for operator[], but not for iterators.
Zero-sized arrays
Unlike standard arrays, the array class can have size zero. The effect of calling front() or back() for a zero-sized array is implementation-defined, but begin() and end() shall return the same unique value. The return value of data() is unspecified for zero-sized arrays.
Differences from standard containers
- The array class does not provide constant-time swap. Instead it provides linear-time swap.
- Because the array class is an aggregate it does not provide fill and range constructors. Its default constructor also does not initialize elements with zeros.
- size() is always constant, based on the second template argument of the type.
- The container provides no allocator support.
Overview of functions
An object of class array can be created using default constructor, copy constructor or initializer list syntax.
expression | description | computational complexity |
---|---|---|
array<T, N> a | create a array object, elements of that have undetermined values | O(1) |
array<T, N> a1(a2) | create a copy of other array object | O(N) |
array<T, N> a = {/*...*/} | create a array object initialized with specified values | O(N) |
The array class provides a swap function and the assignment operator. The only difference from other containers is that swap takes linear time.
expression | return type | description | computational complexity |
---|---|---|---|
swap(a1, a2) | void | swap content of arrays | O(N) |
a1 = a2 | array & | copy content of a2 to a1 | O(N) |
Although TR1 define function assign to fill an array with a specified value, C++0x has the function fill for the same purpose. The boost implementation of array supports both functions.
expression | return type | description | computational complexity |
---|---|---|---|
a.assign(u) | void | fill a with u (TR1 only) | O(N) |
a.fill(u) | void | fill a with u (C++0x only) | O(N) |
The array class provides a standard iterator interface.
expression | return type | description | computational complexity |
---|---|---|---|
a.begin() | [const_]iterator | returns iterator to first element of array | O(1) |
a.end() | [const_]iterator | returns iterator to the one after the last element of array | O(1) |
a.rbegin() | [const_]reverse_iterator | returns reverse iterator to first element of array | O(1) |
a.rend() | [const_]reverse_iterator | returns reverse iterator to the one after the last element of array | O(1) |
The array class provides standard query-capacity functions.
expression | return type | description | computational complexity |
---|---|---|---|
a.size() | size_t | returns size of array | O(1) |
a.max_size() | size_t | returns size of array | O(1) |
a.empty() | bool | a.size() == 0 | O(1) |
The array class provides a standard set of element access functions.
expression | return type | description | computational complexity |
---|---|---|---|
a[i] | T [const] & | returns reference to i-th element | O(1) |
a.at(i) | T [const] & | returns reference to i-th element or throws out_of_range exception | O(1) |
a.front() | T [const] & | returns reference to first element of array | O(1) |
a.back() | T [const] & | returns reference to last element of array | O(1) |
The array class has six standard comparison operators.
expression | return type | description | computational complexity |
---|---|---|---|
a1 < a2 | bool | compare arrays lexicographically | O(N) |
a1 == a2 | bool | compare arrays lexicographically | O(N) |
a1 > a2 | bool | compare arrays lexicographically | O(N) |
a1 <= a2 | bool | compare arrays lexicographically | O(N) |
a1 != a2 | bool | compare arrays lexicographically | O(N) |
a1 >= a2 | bool | compare arrays lexicographically | O(N) |
Raw data access functions.
expression | return type | description | computational complexity |
---|---|---|---|
a.data() | T [const] * | returns pointer to first element of array | O(1) |
a.c_array() | T * | returns pointer to first element of array (non-standard, boost-only, no const-overload) | O(1) |
The array class provides the standard tuple interface.
expression | return type | description |
---|---|---|
tuple_size<array>::value | N | returns size of tuple |
tuple_element<I, array>::type | T | returns type of tuple element |
get<i>(a) | T | returns value of i-th tuple element |
The array class provides the standard set of dependent types.
expression | return type |
---|---|
array<T, N>::reference | T & |
array<T, N>::const_reference | T const & |
array<T, N>::iterator | implementation-defined (T * in boost) |
array<T, N>::const_iterator | implementation-defined (T const * in boost) |
array<T, N>::size_type | size_t |
array<T, N>::difference_type | ptrdiff_t |
array<T, N>::value_type | T |
array<T, N>::reverse_iterator | reverse_iterator<iterator> |
array<T, N>::const_reverse_iterator | reverse_iterator<const_iterator> |