Misplaced Pages

Array (C++): Difference between revisions

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactivelyNext edit →Content deleted Content addedVisualWikitext
Revision as of 20:42, 17 April 2010 editIvansorokin (talk | contribs)50 edits First version  Revision as of 21:08, 17 April 2010 edit undoIvansorokin (talk | contribs)50 editsNo edit summaryNext edit →
Line 10: Line 10:


Standard C arrays has several principal limitation: Standard C arrays has several principal limitation:
* They aren't ]s. They can not be copied like any others objects. * They aren't ]s. They can not be copied like any other object.
* They do not obey standard <tt>operator &</tt> semantics. * They do not obey standard <tt>operator &</tt> semantics.


Line 24: Line 24:
int * b2 = &a; int * b2 = &a;
</source> </source>
<tt>b1</tt> and <tt>b2</tt> receives the same value. That is impossible for object of any others standard types. <tt>b1</tt> and <tt>b2</tt> receives the same value. That is impossible for object of any other standard type.

== Design ==

Array template class is defined in header <tt>&lt;array&gt;</tt> in C++ standard library and in header <tt>&lt;boost/array.hpp&gt;</tt> in boost. It can resides 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 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 type that fulfills <tt>EqualityComparable</tt> or <tt>LessThanComparable</tt> requirements, it fulfills <tt>EqualityComparable</tt> or <tt>LessThanComparable</tt> correspondingly.

Class also provides standard iterators and element access functions.

=== Implementation as aggregate ===

<tt>array</tt> class is implemented as aggregate class. This allow array to be initialized with a brace-enclosing, comma-separated list of initializers for the elements of the container, written in increasing subscript order:

<source lang="cpp">
array<int,4> a = { { 1, 2, 3 } };
</source>

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: passing no initializer list means that the elements have an indetermined 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, you can initialize an array as follows:

<source lang="cpp">
array<int,4> a = { 1, 2, 3 };
</source>


== Links == == Links ==

Revision as of 21:08, 17 April 2010

A array is wrapper class that provide STL-like interface to standard fixed-size C-arrays. It also overcome several limitations of standard array.

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 present slightly modified in his book The C++ Standard Library - A Tutorial and Reference, called carray.

Nicolai Josuttis introduced it under the name array in boost libraries. Later this class was introduced in C++ standard library in TR1.

Motivation

Standard C arrays has several principal limitation:

  • They aren't value types. They can not be copied like any other object.
  • They do not obey standard operator & semantics.

And several minor drawbacks:

  • They do not provide STL-like interface.
  • They do not made bound-checks even in debug builds.
  • They have weird syntax.

The second item means that in the following code

int a;
int * b1 = a;
int * b2 = &a;

b1 and b2 receives the same value. That is impossible for object of any other standard type.

Design

Array template class is defined in header <array> in C++ standard library and in header <boost/array.hpp> in boost. It can resides in namespaces std:: (in C++0x), std::tr1:: (in C++03 with TR1) or boost::.

The array class template 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 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

array class is implemented as aggregate class. This allow array to be initialized with a brace-enclosing, 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 drawbacks: passing no initializer list means that the elements have an indetermined 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, you can initialize an array as follows:

array<int,4> a = { 1, 2, 3 };

Links