动态数组是动态创建的数组,使用new和delete。
new和数组
分配一个数组会得到一个元素类型的指针
初始化动态分配对象的数组,int *p = new int[3]{1,2,3};
动态分配一个空数组是合法的
释放动态数组, delete [] pa;
智能指针和动态数组
unique_ptr<int[]> up (new int[10]);
shared_ptr不直接支持管理动态数组,可以使用lambda表达式作为删除器。
shared_ptr<int> sp (new int [10],[](int *p){delete[] p;});
allocator类:将内存分配和对象构造分离开来
allocato操作
allocato<T> a:定义一个名为a的allocato对象,它可以为类型为T的对象分配内存。
a.allocate(n):分配一段原始的、未构造的内存,保存n个类型为T的对象。
a.deallocate(p,n):释放从T*指针p中地址开始的内存,这块内存保存n个类型为T的对象;p必须是一个先前由allocato返回的指针,且n必须是p创建时所要求的大小。用之前必须先使用destroy。
a.construct(p,args):p必须是一个类型为T*的指针,指向一块原始内存;arg被传递给类型为T的构造函数,用来在p指向的内存中构造一个对象。
a.destroy(p):p为T*类型的指针,此算法对p指向的对象执行析构函数。
allocato算法
uninitialized_copy(b,e,b2):更具迭代器的范围拷贝元素到b2。
uninitialized_copy_n(b,n,b2):从迭代器b指向的元素开始拷贝n个元素到b2。
uninitialized_fill(b,e,t):在迭代器b和e指定的原始内存范围中创建对象,对象的值均为t。
uninitialized_fill_n(b,n,t):从迭代器b开始,创建n个值为t的对象。