基本数据类型存储空间

转自:http://blog.csdn.net/shuishanga/article/details/7313512# 

1.      存储容量单位

        计算机以“位”序列存储数据,每一“位”存储0或1。这里的“位”便是存储信息的一个单位:bit。

        字节:Byte 。1 Byte= 8 bits

        字:“字”由若干个字节构成,字的位数叫做字长,字长就是说字所对应的二进制数的长度。不同的机器有不同的字长。例如一台8位机,它的1个字就等于1个字节,字长为8位。同理:一台16位机,那么,它的1个字就由2个字节构成,字长为16位;而一台32位机,它的1个字就等于4个字节,字长为32位。

2.      基本数据类型存储空间是否确定

        在C和C++中,基本数据类型所占的存储空间是不确定的,这与编译环境或者机器硬件架构有关。在C++中,一般地,short类型为半个机器字长,int类型为一个机器字长,而long 类型为一个或两个机器字长。(在32位机器中,int 和long类型通常字长是相同的)。一般float 用一个字来表示,double用两个字来表示——摘自《C++Primer》。

        在Java中,有8种基本数据类型,它们所占的存储空间是确定的,而这种存储空间大小的不变性是是Java程序比其他语言程序更具可移植性的原因之一。另外Java中所有数据类型都是有符号的。

3.      基本数据类型存储空间

下面在32位win7系统中,分别用Visual Studio 编译C,C++程序,用eclipse编译Java程序。运行结果整理如下:


结果分析:

        对于都存在的数据类型,在测试环境中有两种数据类型存储空间是不同的,上面用蓝色标出。 

测试:(注:C和C++中整型变量存在有符号数和无符号数,Java中都是有符号的,但由于在C和C++中对于某种特定类型而言,有无符号只是取值范围不同而已,并不影响存储空间大小,故测试中采用隐含的形式,即有符号数)

1)  C程序

 #include<stdio.h>  
void main()  
{  
    printf("short: %d\n",sizeof(short));  
    printf("char: %d\n",sizeof(char));  
    printf("int: %d\n",sizeof(int));  
    printf("long: %d\n",sizeof(long));  
    printf("float: %d\n",sizeof(float));  
    printf("double: %d\n",sizeof(double));  
    printf("long double: %d\n",sizeof(long double));  
}  

运行结果:


2) C++程序

 
#include <iostream>  
using namespace std;  
int main()  
{  
    cout<<"bool: "<<sizeof(bool)<<endl;  
    cout<<"short: "<<sizeof(short)<<endl;  
    cout<<"char: "<<sizeof(char)<<endl;  
    cout<<"int: "<<sizeof(int)<<endl;  
    cout<<"long: "<<sizeof(long)<<endl;  
    cout<<"float: "<<sizeof(float)<<endl;  
    cout<<"double: "<<sizeof(double)<<endl;  
    cout<<"long double: "<<sizeof(long double)<<endl;  
    return 0;  
}  

运行结果:


3)Java程序

public class Test {       
    public static void main(String args[] ) {  
        System.out.println("byte: "+Byte.SIZE/8);  
        System.out.println("short: "+Short.SIZE/8);  
        System.out.println("char: "+Character.SIZE/8);  
        System.out.println("int: "+Integer.SIZE/8);  
        System.out.println("long: "+Long.SIZE/8);  
        System.out.println("folat: "+Float.SIZE/8);  
        System.out.println("double: "+Double.SIZE/8);  
    }  
}  

运行结果:

转载于:https://www.cnblogs.com/zhangxiaosong/p/3322582.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值