public member function
<set>

std::multiset::get_allocator

allocator_type get_allocator() const;
allocator_type get_allocator() const noexcept;
获取分配器
返回与该 multiset 相关联的分配器对象的副本。

参数



返回值

分配器。

成员类型allocator_type是容器使用的分配器的类型,在 multiset 中定义为其第三个模板参数的别名(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
// multiset::get_allocator
#include <iostream>
#include <set>

int main ()
{
  std::multiset<int> mymultiset;
  int * p;
  unsigned int i;

  // allocate an array of 5 elements using myset's allocator:
  p=mymultiset.get_allocator().allocate(5);

  // assign some values to array
  for (i=0; i<5; i++) p[i]=(i+1)*10;

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

  mymultiset.get_allocator().deallocate(p,5);

  return 0;
}
该示例演示了一种复杂的内存分配方法,用于分配一系列int,使用与容器相同的分配器。
输出
The allocated array contains: 10 20 30 40 50


复杂度

常量。

迭代器有效性

没有变化。

数据竞争

访问容器。
同时访问 multiset 的元素是安全的。

异常安全

无异常保证:此成员函数从不抛出异常。
复制任何 默认分配器 的实例化也被保证永远不会抛出异常。

另见