zoukankan      html  css  js  c++  java
  • 为什么需要定义数据类型???

    变量和数据类型难舍难分,思考了好久,得出下面这个结论:


    变量是内存中的一个存储区域。而数据类型的定义决定了这块存储区域的大小。【变量与数据类型的关系】


    为什么需要定义变量存储区域的大小?


    以结果为导向来分析:

    Java的整数类型分为4种:byte,short,int,long。

    四种的区别在于占用的存储空间不一样。

    byte占用1个字节,short占用2个字节,int占用4个字节,而long占用8个字节。


    什么是字节?

    字节是一种存储单位的度量。1个字节等于8位。

    什么是位呢?

    位可以理解为计算机的最小单位:0或者是1。也就是是说1个字节是8个0和1的排列组合:

    比如说:00000000,00000001,00000011,......11111111。


    那么在这种情况下1个字节可以表示多大的数呢?

    00000000转换为十进制依然是0,11111111转换为十进制是255。

    转换工具:https://tool.lu/hexconvert/

    也就是说,一个字节最大可以表示255而最小1可以表示0。


    这是无符号位的情况,如果8位表示正数和负数,那么8位可以表示的范围是多大呢?

    通常情况下,用第一位来表示正负【0为正,1为负】,这样算下来8位可以表示的范围是-127到+127。

    历史长河中,补码登场

    上述引入符号位的8位二进制数可以理解为原码。对于正数来说,原码就是补码,而对于负数来说,保留符号位,其他原码按位取反加1所得即为补码。补码的出现使得加减法只有加法,简化了计算结构,提高运算速度。


    那么8位的情况下,用补码来衡量,可以表达的范围是-128--127。

    为什么是-128???(按照补码计算)

    10000001到11111111表示的范围是1到127,01111110到00000001表示的范围是-1到-127。

    而00000000属于负数,按位取反加1的结果是10000000表示的数值是-128,但是00000000是负数。

    所以8位二进制数在计算机里存储的范围是-128--127。


    回到刚刚字节的问题,1字节等于8位而八位可以表示-128--127。这是byte类型的表示范围。


    那如果我想用计算机计算1000加上1000,byte明显是不可用的。因为byte表示不了1000这个数值。

    而short类型的存储空间为2个字节,也就是16位。对于short数据类型来说,能表示多大的数呢?

    根据8位的表示范围推算:- 2的15次方到2的15次方-1=={-32768--32767}


    以此类推,int为4个字节,long为8个字节,能表示的数更大。


    Java通过定义变量的类型来规定变量的内存空间大小,通过阶梯式的定义,既有满足小数值运行的byte类型,也有支持大数值运算的long类型。这样不仅满足运算的最大支持(long),同时也能节省系统内存资源(byte)。



    总结:数据类型的区分是一种系统资源分配优化的方案。

  • 相关阅读:
    终于看到费德勒在法网如愿!
    o(∩_∩)o...,今天去博客园了!
    条款4:使用Conditional特性代替#if条件编译
    MSDTC无法启动的解决方法
    2009 很有意义的一天
    从现在开始,争取记录每天所学到的、所感受到的、所遇见到的点点滴滴!
    了解MOSS2007 内容类型ID(Content Type IDs)命名规则
    CreateSpecificCulture('zhcn')和new CultureInfo('zhcn')的区别
    金华大显数码科技有限公司诚聘
    使用SQL Server中按位于来表示组合状态
  • 原文地址:https://www.cnblogs.com/noneplus/p/11390853.html
Copyright © 2011-2022 走看看