zoukankan      html  css  js  c++  java
  • Java语言中:在数据类型的讲解中补充的几个小问题

    =============================================================================
    1:在定义Long或者Float类型变量的时候,要加L或者f。
      整数默认是int类型,浮点数默认是double。

      byte,short在定义的时候,他们接收的其实是一个int类型的值。
      这个是自己做了一个数据检测的,如果不再它们的范围内,就报错。
      例如:
        byte a = 50; // 其实50是int类型的。
        short b = 100; // 其实100是int类型的。
    -----------------------------------------------------------------------------
    2:byte值的问题:即默认是有符号的
      byte b1 = 127; // 127
      byte b2 = (byte)128; // -128
      byte b3 = (byte)129; // -127
      byte b4 = (byte)130; // -126
      ......
      byte b4 = (byte)255; // -1
      byte b4 = (byte)256; // 0
      byte b4 = (byte)257; // +1
    ---------------------------------------
      byte b1 = -128; // -128
      byte b2 = (byte)-129; // +127
      byte b3 = (byte)-130; // +126
      byte b4 = (byte)-131; // +125
      ......
      byte b4 = (byte)-255; // +1
      byte b4 = (byte)-256; // 0
      byte b4 = (byte)-257; // -1
    ---------------------------------------
      所以有个规律是:在任何范围内,如果给个较大的值,在截取的时候,当比最大值还大的时候,又会绕回去从最小的开始。
      所以有个规律是:在任何范围内,如果给个较小的值,在截取的时候,当比最小值还小的时候,又会绕回去从最大的开始。
    ---------------------------------------
      byte的范围:-128 ~ 127

      128: 1000 0000
      -128:1000 0000 (可以这样认为:这里的1既是符号位,也是数值位。)

      其实1000 0000表示-0。
      其实实际上byte的范围是 -127,-126,-125,...,-1,-0,+0,+1,...,+125,+126,+127
      但是呢我们一般认为的是0不分正负的,所以为了区别以及为了超过范围数还能绕回去,叫做数据的回环!,就上面那样做了。
    -----------------------------------------------------------------------------
    3:数据类型转换之默认转换:
      byte,short,char --> int --> long --> float --> double
              默认转换
      但是呢?
        long: 8个字节
        float:4个字节
      为什么long会在前面呢?
    ---------------------------------------
      原因是:
        A:它们底层的存储结构不同。所有的整数是按照1010...去存储的,但浮点数是按照科学计数法的表示的,所以存储的有效数字位以及次幂。
        B:这样就导致了float表示的数据范围比long的范围要远远大。
          long:-2^63 ~ 2^63-1
          float:3.4*10^38 > 2*10^38 > 2*8^38 = 2*2^3^38 = 2*2^114 >> 2^63-1
    ---------------------------------------
      Java浮点类型常量有两种表示形式:
        十进制数形式,     如:3.14         314.0
        科学记数法形式, 如:3.14e2    3.14*10^2
      Java各整数类型有固定的表数范围和字段长度,其不受具体操作系统的影响,以保证Java程序的可移植性
      所谓的有效数字:具体地说,是指在分析工作中实际能够测量到的数字。所谓能够测量到指的是包括最后一位估计的不确定的数字。
        例如:对于一个近似数,从左边第一个不是0的数字起,到精确到的位数止,所有的数字都叫做这个数的有效数字。
    -----------------------------------------------------------------------------
    4:面试题:Java语言中的字符char可以存储一个中文汉字吗?为什么呢?
      可以。因为java语言中的字符char占用两个字节。

      Java语言采用的是Unicode编码。(Unicode是全球语言统一编码)
    =============================================================================

  • 相关阅读:
    CF767C Garland
    P2458 [SDOI2006]保安站岗
    P2704 [NOI2001]炮兵阵地
    P2607 [ZJOI2008]骑士
    POJ 1201 Interval (查分约束系统)
    位运算的魅力---N皇后问题
    设计模式之代理模式20170724
    C之Volatile关键字的介绍与使用20170724
    设计模式之桥梁模式20170721
    设计模式之策略模式20170720
  • 原文地址:https://www.cnblogs.com/chenmingjun/p/8415063.html
Copyright © 2011-2022 走看看