C++ 基礎(chǔ)教程

C++ 流程控制

C++ 函數(shù)

C++ 數(shù)組 & 字符串

C++ 數(shù)據(jù)結(jié)構(gòu)

C++ 類 & 對象

C++ 指針

C++ 繼承

C++ STL 教程

C++ 參考手冊

C++ set get_allocator() 使用方法及示例

C++ STL Set(集合)

C ++ set get_allocator()函數(shù)用于返回分配器對象的副本,該對象有助于構(gòu)造set容器。

語法

           allocator_type get_allocator() const; 		//C++ 11 之前
allocator_type get_allocator() const noexcept; 	//C++ 11 之后

參數(shù)

沒有

返回值

返回與集合容器關(guān)聯(lián)的分配器。

復(fù)雜

不變。

迭代器有效性

沒有變化。

數(shù)據(jù)爭用

容器被訪問。

同時訪問set的元素是安全的。

異常安全

此函數(shù)從不拋出異常。

實例1

讓我們看一個簡單的實例:

#include <iostream>
#include <set>

using namespace std;

int main(void) {
   set<double> m;   
   double *p;

   p = m.get_allocator().allocate(3);

   //double 為 8
   cout << "分配的大小 = " <<  sizeof(*p) * 4 << endl;

   return 0;
}

輸出:

分配的大小 = 32

實例2

讓我們看一個簡單的實例:

#include <iostream>
#include <set>

using namespace std;

int main ()
{
  set<int> myset;
  int * p;
  unsigned int i;

  // 使用myset的分配器分配一個包含5個元素的數(shù)組:
  p=myset.get_allocator().allocate(5);

  // 給數(shù)組賦一些值
  for (i=0; i<5; i++) p[i]=(i+1)*10;

  cout << "已分配的數(shù)組包含:";
  for (i=0; i<5; i++) cout << ' ' << p[i];
  cout << '\n';

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

  return 0;
}

輸出:

已分配的數(shù)組包含: 10 20 30 40 50

實例3

讓我們看一個簡單的示例,檢查分配器是否可互換:

#include <set>  
#include <iostream>  
using namespace std;

int main()
{
    
    set<int>::allocator_type s1_Alloc;
    set<int>::allocator_type s2_Alloc;
    set<double>::allocator_type s3_Alloc;
    set<int>::allocator_type s4_Alloc;

    //以下行聲明對象
    //使用默認(rèn)分配器。  
    set<int> s1;
    set<int>::allocator_type s2;
    set<double>::allocator_type s3;

    s1_Alloc = s1.get_allocator();


    cout << "可以分配的整數(shù)數(shù)量"
        << endl << "在空閑內(nèi)存耗盡之前: "
        << s2.max_size() << "." << endl;

    cout << "\n可以分配的雙浮點數(shù)"
        << endl << "在空閑內(nèi)存耗盡之前: "
        << s3.max_size() << "." << endl;

    //以下行創(chuàng)建一個集合s4
    //使用多重集合s1的分配器。
    set <int> s4(less<int>(), s1_Alloc);

    s4_Alloc = s4.get_allocator();

    //如果兩個分配器可以互換
    //每個分配的存儲空間可以是
    //被另一個釋放
    if (s1_Alloc == s4_Alloc)
    {
        cout << "\n這些分配器是可互換的。"<< endl;
    }
    else
    {
        cout << "\n這些分配器是不可互換的。"<< endl;
    }
   return 0;
}

輸出:

可以分配的整數(shù)數(shù)量
在空閑內(nèi)存耗盡之前: 1073741823.

可以分配的雙浮點數(shù)
在空閑內(nèi)存耗盡之前: 536870911.

這些分配器是可互換的。

實例4

讓我們看一個簡單的實例:

#include <iostream>
 #include <set>

using namespace std;

int  main () 
{ 
  set < int >  c ; 
  int *  p ;

  p  =  c . get_allocator () . allocate ( 2 );

  p [ 0 ]  =  42 ; 
  p [ 1 ]  =  43 ;

  cout  <<  p [ 0 ]  <<  ", "  <<  p [ 1 ]  <<  endl ;

  c . get_allocator () . deallocate ( p ,  2 ); 
}

輸出:

42, 43

C++ STL Set(集合)

丰满人妻一级特黄a大片,午夜无码免费福利一级,欧美亚洲精品在线,国产婷婷成人久久Av免费高清