boost array

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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值