整体来说C++/C中的最大值是跟编译器有关的,事关具体类型的存储形式。
对于int型数据,一般机器都是以4Bytes来存储,也就是说对于无符号类型的最大值为2^32-1=4294967295,对应的二进制码为:0xffffffff(四字节全1);对于有符号来说其最大值最小值范围为:-2^31~2^21-1,其中-2^31=-2147483648,二进制码字为0x80000000(符号位1,其余全0);2^21-1=0x7fffffff(符号位为0,其余全1);
具体到代码中的实现方法:
1、直接定义二进制序列
const unsigned int MAX_UINT = 0xffffffff;
const int MAX_INT = 0x7fffffff;
const int MIN_INT = 0x80000000;
2、当然还有系统自带的最值
std::numeric_limits<unsigned int>::max()
std::numeric_limits<int>::max()
std::numeric_limits<int>::min()
以上是C++调用格式,也可以直接调用系统常数INT_MAX等,可以直接输出最值,参考 http://msdn.microsoft.com/en-us/library/296az74e%28VS.80%29.aspx。
这些数据的类型是可以改变的,如char、short、long等,但都必须是整形数据。
参考代码例子:
#include <iostream>
#include <limits>
int main()
{
const unsigned int MAX_UINT = 0xffffffff;
const int MAX_INT = 0x7fffffff;
const int MIN_INT = 0x80000000;
std::cout<<"自定义的最值:无符号最大值:"<<MAX_UINT<<std::endl;
std::cout<<"自定义的最值:有符号最大值:"<<MAX_INT<<std::endl;
std::cout<<"自定义的最值:有符号最小值:"<<MIN_INT<<std::endl;
std::cout<<"调用系统最值函数:无符号最大值:"<<std::numeric_limits<unsigned int>::max()<<std::endl;
std::cout<<"调用系统最值函数:有符号最大值:"<<std::numeric_limits<int>::max()<<std::endl;
std::cout<<"调用系统最值函数:有符号最小值:"<<std::numeric_limits<int>::min()<<std::endl;
std::cout<<"调用系统常数:无符号最大值:"<<UINT_MAX<<std::endl;
std::cout<<"调用系统常数:有符号最大值:"<<INT_MAX<<std::endl;
std::cout<<"调用系统常数:有符号最小值:"<<INT_MIN<<std::endl;
system("pause");
return 0;
}
输出为: