数据溢出

基本数据类型

基本数据类型分两大类:ios

  1. 整型
  2. 浮点型
  • 整型包括char,short,int,long,long long
  • 除此以外,整型还有无符号类型unsigned ...
  • 浮点型包括float,double,long double

规则:

short至少16位,int至少和short同样长;

long至少32位,至少和int同样长;

long long至少64位,至少和long同样长。



float至少4个字节;

double至少6个字节,而且很多于float;

long double至少和double同样长。操作系统

数据范围

不一样的系统环境,数据范围有所不一样;32位/64位操做系统,数据范围也有所不一样。

能够经过代码来肯定不一样的范围:
code

  1. c语言定义了一系列的宏
#include <stdio.h>
#include <limits.h>

int main()
{
    printf("max integer: %d\n", INT_MAX);
    printf("min integer: %d\n", INT_MIN);
    return 0;
}
  1. C++ 数值极限
#include <iostream>
#include <limits>

int main()
{
    std::cout << numeric_limits<int>::max() << endl;
    std::cout << numeric_limits<int>::min() << endl;
    return 0;
}

数据类型应用

介绍个亲身遇到的数据溢出的问题。
it

  1. 数据压缩后还原致使溢出
int d = 0;
long value = d * 1000 + 10;

上面一段代码就有发生数据溢出的可能。当变量d足够大时,再乘以1000就会溢出。结果可想而知,是一个相对小的数值。io

//能够这样改写,就不会出现问题
long value = (long)d * 1000 + 10;
  • C/C++基本数据类型,每一种都有范围。在选择数据类型要注意合适的范围,不然会形成数据溢出,产生难以发现的bug。
相关文章
相关标签/搜索