public member function
<deque>

std::deque::get_allocator

allocator_type get_allocator() const;
allocator_type get_allocator() const noexcept;
獲取分配器
返回與 deque 物件關聯的分配器物件的副本。

引數



返回值

分配器。

成員型別allocator_type是容器使用的分配器型別,在 deque 中定義為第二個模板引數 (Alloc).

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// deque::get_allocator
#include <iostream>
#include <deque>

int main ()
{
  std::deque<int> mydeque;
  int * p;
  unsigned int i;

  // allocate an array with space for 5 elements using deque's allocator:
  p = mydeque.get_allocator().allocate(5);

  // construct values in-place on the array:
  for (i=0; i<5; i++) mydeque.get_allocator().construct(&p[i],i);

  std::cout << "The allocated array contains:";
  for (i=0; i<5; i++) std::cout << ' ' << p[i];
  std::cout << '\n';

  // destroy and deallocate:
  for (i=0; i<5; i++) mydeque.get_allocator().destroy(&p[i]);
  mydeque.get_allocator().deallocate(p,5);

  return 0;
}
該示例演示了一種複雜的記憶體分配方法,用於分配一系列int使用與 deque 物件相同的分配器。輸出
The allocated array contains: 0 1 2 3 4


複雜度

常量。

迭代器有效性

沒有變化。

資料競爭

訪問容器。
不訪問任何包含的元素:併發訪問或修改它們是安全的。

異常安全

無異常保證:此成員函式從不丟擲異常。
複製任何 預設分配器 的例項也保證永遠不會丟擲異常。

另見