在本文中,我们将讨论C ++ STL中的set::get_allocator()函数,其语法,工作原理和返回值。
C ++ STL中的集合是必须按常规顺序具有唯一元素的容器。集必须具有唯一元素,因为元素的值标识该元素。一旦在集合容器中添加了值,以后就无法修改,尽管我们仍然可以删除或将值添加到集合中。集用作二进制搜索树。
get_allocator()函数是C ++ STL中的内置函数,在<set>头文件中定义。此函数返回与其关联的集合容器的分配器对象的副本。get_allocator()用于将内存块分配给设置的容器。
分配器是一个对象,负责动态设置容器的内存分配。
Set1.get_allocator();
此函数不接受任何参数
此函数返回其对象与该函数关联的分配器或分配器的副本。
#include <iostream> #include <set> using namespace std; void input(int* arr){ for(int i = 0; i <= 5; i++) arr[i] = i; } void output(int* arr){ for (int i = 0; i <= 5; i++) cout << arr[i] << " "; cout << endl; } int main(){ set<int> mySet; int* arr; arr = mySet.get_allocator().allocate(6); input(arr); output(arr); mySet.get_allocator().deallocate(arr, 6); return 0; }
输出结果
如果我们运行上面的代码,那么它将生成以下输出-
0 1 2 3 4 5