array本质上是一个对静态数组的包装,没有构造函数,不能指定大小,不能动态增长
template<class T,std::size_t N>
class array{
public:
T elems[N];
//迭代器的首指针,末指针加1
iterator begin();
iterator end();
reference operator[](size_type i);
reference at(size_type i);
//返回首末元素的引用,相当于elems[0],elems[N-1]
reference front();
reference back();
static size_type size();
static bool empty();
static size_type max_size();
//以c数组的形式返回内部数组指针,用于需要原始指针的场合
T* data();
T* c_array();
void swap(array<T,N>& y);//交换两个array
void assign(const T& value);
};
#include<boost/array.hpp>
#include<iostream>
using namespace boost;
using namespace std;
template<typename T>
void printArray(const T& t)
{
typename T::const_iterator iter;
for(iter = t.begin();iter!=t.end();++iter){
cout << *iter << " ";
}
cout << endl;
}
int main()
{
array<int,10> ar;
ar.assign(100);//把所有的值设成100
ar[0] = 1;
ar.back() = 10;//将最后一个值设成10
assert(ar[ar.max_size()-1]==10);
printArray(ar);
int *p = ar.c_array(); //获得原始数组指针
*(p+5) = 123;
cout << "ar[5]:" << ar[5] << endl;
ar.at(8)=345;
sort(ar.begin(),ar.end());//可以使用标准算法排序
cout << "sort:";
printArray(ar);
}
1 100 100 100 100 100 100 100 100 10
ar[5]:123
sort:1 10 100 100 100 100 100 100 123 345