C ++ map max_size()函数用于获取map容器可以容纳的最大大小。
成员类型size_type是无符号整数类型。
size_type max_size() const; // 在 C++ 11 之前 size_type max_size() const noexcept; //从 C++ 11 开始
没有
它返回map容器的最大允许长度。
让我们看一个简单的示例来计算map的最大容量。
#include <iostream>
#include <map>
using namespace std;
int main()
{
map<char,char> s;
cout << "map的最大大小是 " << s.max_size() << "\n";
}输出:
map的最大大小是 268435455
在上面的示例中,max_size()函数返回map的最大容量。
让我们看一个简单的实例。
#include <iostream>
#include <map>
using namespace std;
int main ()
{
int i;
map<int,int> mymap;
if (mymap.max_size()>1000)
{
for (i=0; i<1000; i++) mymap[i]=0;
cout << "该map包含1000个元素。\n";
}
else cout << "map不能容纳1000个元素。\n";
return 0;
}输出:
该map包含1000个元素。
在上面的示例中,成员max_size用于预先检查该map是否允许插入1000个元素。
让我们看一个简单的示例,查找一个空map和一个非空map的最大大小。
#include <map>
#include <iostream>
using namespace std;
int main()
{
//初始化容器
map<int, int> mp1, mp2;
mp1[1] = 1111;
//非空map的最大大小
cout << "mp1的最大大小为 " << mp1.max_size();
// 空map的最大大小
cout << "\nmp2的最大大小为 " << mp2.max_size();
return 0;
}输出:
mp1的最大大小为 178956970 mp2的最大大小为 178956970
在上面的示例中,有两个map,即m1和m2。m1是一个非空map,m2是一个空map。但是,两个map的最大大小是相同的。
让我们看一个简单的实例。
#include <iostream>
#include <map>
#include <string>
using namespace std;
int main() {
typedef map<string, int> city;
string name;
int age;
city fmly ;
int n;
cout<<"输入家庭成员人数 :";
cin>>n;
cout<<"输入每个成员的姓名和年龄: \n";
for(int i =0; i<n; i++)
{
cin>> name;
cin>> age;
fmly[name] = age;
}
cout<<"\n城市总人口map: "<<fmly.max_size();
cout<<"\n家庭总成员是:"<< fmly.size();
cout<<"\n家庭成员的详细信息: \n";
cout<<"\nName | Age \n ________________________\n";
city::iterator p;
for(p = fmly.begin(); p!=fmly.end(); p++)
{
cout<<(*p).first << " | " <<(*p).second <<" \n ";
}
return 0;
}输出:
输入家庭成员人数 : 3 输入每个成员的姓名和年龄: Ram 42 Sita 37 Laxman 40 城市总人口map: 384307168202282325 家庭总成员是:3 家庭成员的详细信息: Name | Age __________________________ Laxman | 40 Ram | 42 Sita | 37
在上面的示例中,程序首先以给定的大小交互创建城市map。然后,它显示城市map可以包含的总大小,每张照片的总大小以及map中所有可用的名称和年龄。