C++中整数最值的表示方法

整体来说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::max()
std::numeric_limits::max()
std::numeric_limits::min()

以上是C++调用格式,也可以直接调用系统常数INT_MAX等,可以直接输出最值,参考 http://msdn.microsoft.com/en-us/library/296az74e%28VS.80%29.aspx。

这些数据的类型是可以改变的,如char、short、long等,但都必须是整形数据。



参考代码例子:

#include 
#include 
int main()
{
	const unsigned int MAX_UINT = 0xffffffff;
	const int  MAX_INT = 0x7fffffff;
	const int  MIN_INT  = 0x80000000;
	std::cout<<"自定义的最值:无符号最大值:"<::max()<::max()<::min()<



输出为:

C++中整数最值的表示方法_第1张图片

你可能感兴趣的:(C++)