规定int8位,那么char,short,long,float,double各是几位啊???谢谢了~~~

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了规定int8位,那么char,short,long,float,double各是几位啊???谢谢了~~~相关的知识,希望对你有一定的参考价值。

int不是8位,char为8位。ANSI C规定int的最小值为16位,目前个人计算机int大多为32位,short为16位,long为32位,float为32位,double为64位。 参考技术A 擦你嘴,于桧,.

数据溢出

基本数据类型

基本数据类型分两大类:

  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位操作系统,数据范围也有所不同。

可以通过代码来确定不同的范围:

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

int main()
{
    printf("max integer: %d
", INT_MAX);
    printf("min integer: %d
", 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;
}

数据类型应用

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

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

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

//可以这样改写,就不会出现问题
long value = (long)d * 1000 + 10;
  • C/C++基本数据类型,每一种都有范围。在选择数据类型要注意合适的范围,否则会造成数据溢出,产生难以发现的bug。



















以上是关于规定int8位,那么char,short,long,float,double各是几位啊???谢谢了~~~的主要内容,如果未能解决你的问题,请参考以下文章

typedef char int8; 这样定义的好处?

Java中char,short,int,long占几个字节和多少位

C++中long,short,int的具体区别是啥?

java中的char,short,int,long占几个字节

笔试题集锦

32位操作系统中,int,long占用4字节,short占用2字节…… 那64位的呢