我看JAVA 之 基本数据类型与封装类型

简介:

我看JAVA 之 基本数据类型与封装类型

注:基于jdk11
java提供了8中基本数据类型,其中1个布尔类型,6个数字类型,1个字符类型。同时jdk为这8种基本数据类型提供了相应的封装类型。

boolean & Boolean

  • boolean

    1. 长度为1位
    2. 数据范围:只有两个值true、false
    3. 默认值为false
  • Boolean

    1. boolean的封装类型
    2. 实现了Serializable、Comparable接口
    3. 重要的成员变量

      public static final Boolean TRUE = new Boolean(true);
      public static final Boolean FALSE = new Boolean(false);
      private final boolean value;
      public static final Class<Boolean> TYPE = (Class<Boolean>) Class.getPrimitiveClass("boolean");
    4. 重要的方法

      @HotSpotIntrinsicCandidate
      public boolean booleanValue() {
        return value;
      }  
      @HotSpotIntrinsicCandidate
      public static Boolean valueOf(boolean b) {
        return (b ? TRUE : FALSE);
      }   

byte & Byte

  • byte

    1. 长度为1个字节,有符号
    2. 数据范围:最小值-2^7,最大值2^7-1 即[-128, 127]共256个数字
    3. 默认值为0
  • Byte

    1. 继承了Number类, Number抽象类定义了类型转换的抽象方法如intValue()longValue()floatValue()等,并实现了序列化接口
    2. 实现了Comparable接口
    3. 重要的成员变量

      public static final byte   MIN_VALUE = -128;
      public static final byte   MAX_VALUE = 127;
      @SuppressWarnings("unchecked")
      public static final Class<Byte>     TYPE = (Class<Byte>) Class.getPrimitiveClass("byte");
    4. 重要的方法

      @HotSpotIntrinsicCandidate
      public static Byte valueOf(byte b) {
          final int offset = 128;
          return ByteCache.cache[(int)b + offset];
      }
      @HotSpotIntrinsicCandidate
      public byte byteValue() {
          return value;
      }
    5. 缓存机制

      private static class ByteCache {
          private ByteCache(){}
      
          static final Byte cache[] = new Byte[-(-128) + 127 + 1];
      
          static {
              for(int i = 0; i < cache.length; i++)
                  cache[i] = new Byte((byte)(i - 128));
          }
      }

      静态内部类ByteCache内部的静态Byte[]缓存了Byte的全部256个数据。

int & Integer

  • int

    1. 长度为4个字节,有符号
    2. 数据范围:最小值-2^31,最大值2^31-1 即[0x80000000, 0x7fffffff]
    3. 默认值为0
  • Integer

    1. 继承了Number类
    2. 实现了Comparable接口
    3. 重要的成员变量

      @Native public static final int   MIN_VALUE = 0x80000000;
      
      /**
       * A constant holding the maximum value an {@code int} can
       * have, 2<sup>31</sup>-1.
       */
      @Native public static final int   MAX_VALUE = 0x7fffffff;
      
      /**
       * The {@code Class} instance representing the primitive type
       * {@code int}.
       *
       * @since   1.1
       */
      @SuppressWarnings("unchecked")
      public static final Class<Integer>  TYPE = (Class<Integer>) Class.getPrimitiveClass("int");
      
      /**
       * All possible chars for representing a number as a String
       */
      static final char[] digits = {
          '0' , '1' , '2' , '3' , '4' , '5' ,
          '6' , '7' , '8' , '9' , 'a' , 'b' ,
          'c' , 'd' , 'e' , 'f' , 'g' , 'h' ,
          'i' , 'j' , 'k' , 'l' , 'm' , 'n' ,
          'o' , 'p' , 'q' , 'r' , 's' , 't' ,
          'u' , 'v' , 'w' , 'x' , 'y' , 'z'
      };
      
      @Native public static final int SIZE = 32; 32位
      public static final int BYTES = SIZE / Byte.SIZE; 32/8=4 4个字节
    4. 重要的方法

      @HotSpotIntrinsicCandidate
      public static String toString(int i) {
          int size = stringSize(i);
          if (COMPACT_STRINGS) {
              byte[] buf = new byte[size];
              getChars(i, size, buf);
              return new String(buf, LATIN1);
          } else {
              byte[] buf = new byte[size * 2];
              StringUTF16.getChars(i, size, buf);
              return new String(buf, UTF16);
          }
      }
      
      //使用缓存IntegerCache,使用valueOf在空间和时间上要优于直接使用构造方法
      @HotSpotIntrinsicCandidate
      public static Integer valueOf(int i) {
          if (i >= IntegerCache.low && i <= IntegerCache.high)
              return IntegerCache.cache[i + (-IntegerCache.low)];
          return new Integer(i);
      }
      @HotSpotIntrinsicCandidate
      public int intValue() {
          return value;
      }
    5. 有意思的方法:

      System.out.println(Integer.numberOfLeadingZeros(18));
      System.out.println(Integer.numberOfTrailingZeros(1000));
      System.out.println(Integer.bitCount(1));
      System.out.println(Integer.bitCount(2));
      System.out.println(Integer.bitCount(4));
      System.out.println(Integer.bitCount(12));
       
      打印结果如下:
      27 整数18在二进制表示中首部有27个连续的0
      3  整数1000在二进制表示中尾部有3个连续的0
      1  整数1在二进制表示中有1位是1
      1  整数2在二进制表示中有1位是1
      1  整数4在二进制表示中有1位是1
      2  整数12在二进制表示中有2位是1 
    6. 缓存机制

      private static class IntegerCache {
          static final int low = -128;
          static final int high; //通过设置-XX:AutoBoxCacheMax=<size>,指定high的值,默认缓存范围为[-128,127]
          static final Integer cache[];
      
          static {
              // high value may be configured by property
              int h = 127;
              String integerCacheHighPropValue =
                  VM.getSavedProperty("java.lang.Integer.IntegerCache.high");
              if (integerCacheHighPropValue != null) {
                  try {
                      int i = parseInt(integerCacheHighPropValue);
                      i = Math.max(i, 127);
                      // Maximum array size is Integer.MAX_VALUE
                      h = Math.min(i, Integer.MAX_VALUE - (-low) -1);
                  } catch( NumberFormatException nfe) {
                      // If the property cannot be parsed into an int, ignore it.
                  }
              }
              high = h;
      
              cache = new Integer[(high - low) + 1];
              int j = low;
              for(int k = 0; k < cache.length; k++)
                  cache[k] = new Integer(j++);
      
              // range [-128, 127] must be interned (JLS7 5.1.7)
              assert IntegerCache.high >= 127;
          }
      
          private IntegerCache() {}
      }
      

      验证缓存代码示例:

      package chapter01;
      public class TestInteger {
          public static void main(String [] args) {
              Integer a = Integer.valueOf(6);
              Integer b = new Integer(6);
              Integer c = 6;
      
              System.out.println(a==b);
              System.out.println(a==c);
              System.out.println(c==b);
      
              Integer a1 = Integer.valueOf(600);
              Integer b1 = new Integer(600);
              Integer c1 = 600;
              System.out.println("\n");
      
              System.out.println(a1==b1);
              System.out.println(a1==c1);
              System.out.println(c1==b1);
      
          }
      }
      打印结果:
      false
      true
      false
      
      
      false
      false
      false
      建议:
      包装类型比较是否相等使用equals()而非==

long & Long

  • long

    1. 长度为8个字节,有符号
    2. 数据范围:最小值-2^63,最大值2^63-1 即[0x8000000000000000L, 0x7fffffffffffffffL]
    3. 默认值为0
  • Long

    
    类似 integer,读者可以自己去分析

float & Float

  • float

    1. 是单精度、长度为4个字节共32位、符合IEEE 754标准的浮点数
    2. 默认值为0.0f
    3. float与double精度不同,所以在将float与double强制转换的时候会出现精度丢失的问题
  • Float

    1. 继承了Number类, Number抽象类定义了类型转换的抽象方法如intValue()longValue()floatValue()等,并实现了序列化接口
    2. 实现了Comparable接口
    3. 重要的成员变量
    public static final float POSITIVE_INFINITY = 1.0f / 0.0f; 正无穷
    public static final float NEGATIVE_INFINITY = -1.0f / 0.0f;负无穷
    public static final float NaN = 0.0f / 0.0f; //不是数字 Not a Number
    public static final float MAX_VALUE = 0x1.fffffeP+127f; // 3.4028235e+38f
    public static final float MIN_NORMAL = 0x1.0p-126f; // 1.17549435E-38f
    public static final float MIN_VALUE = 0x0.000002P-126f; // 1.4e-45f
    
    //最大、最小指数
    public static final int MAX_EXPONENT = 127;
    public static final int MIN_EXPONENT = -126;
    
    //32位,4个字节
    public static final int SIZE = 32;
    public static final int BYTES = SIZE / Byte.SIZE;
    
    @SuppressWarnings("unchecked")
    public static final Class<Float> TYPE = (Class<Float>) Class.getPrimitiveClass("float");

double & Double

  • double

    1. 是双精度、长度为8个字节共64位、符合IEEE 754标准的浮点数
    2. 默认值为0.0d
  • Double

    类似 Float,读者可以自己去分析
    

short & Short

  • short

    1. 长度为2个字节,有符号
    2. 数据范围:最小值-2^15,最大值2^15-1 即[-32768, 32767]
    3. 默认值为0
  • Short

    类似 Integer,读者可以自己去分析

char & Character

  • char

    1. 单个unicode字符,长度为16位
    2. 数据范围:最小值0,最大值65535 即[0, 65535]
    3. 默认值为""
  • Character
相关文章
|
30天前
|
存储 缓存 安全
Java中的数据类型
Java语言提供了八种基本类型,分为4类8种:六个数值型(四个整数型byte、short、int、long,两个浮点型float、double)、一个字符型char和一个布尔型boolean。每种基本类型有固定的位数、取值范围及默认值。此外,还存在`void`类型,但无法直接操作。基本类型支持隐式和显式类型转换,并有对应的包装类如`Integer`、`Double`等,用于在需要对象的场景中使用。包装类支持自动装箱与拆箱机制,简化了基本类型与引用类型的转换,但需要注意性能和空指针异常等问题。
Java中的数据类型
|
3天前
|
存储 Java 测试技术
Java基础(三):八种基本数据类型
Java基础(三):八种基本数据类型
Java基础(三):八种基本数据类型
|
1天前
|
Java
Java 面向对象编程的三大法宝:封装、继承与多态
本文介绍了Java面向对象编程中的三大核心概念:封装、继承和多态。
31 15
|
2月前
|
Java
Java基础之数据类型
Java基础之数据类型
24 6
|
2月前
|
Java
在Java中如何将基本数据类型转换为String
在Java中,可使用多种方法将基本数据类型(如int、char等)转换为String:1. 使用String.valueOf()方法;2. 利用+运算符与空字符串连接;3. 对于数字类型,也可使用Integer.toString()等特定类型的方法。这些方法简单高效,适用于不同场景。
133 7
|
2月前
|
存储 Java 开发者
Java 中 Set 类型的使用方法
【10月更文挑战第30天】Java中的`Set`类型提供了丰富的操作方法来处理不重复的元素集合,开发者可以根据具体的需求选择合适的`Set`实现类,并灵活运用各种方法来实现对集合的操作和处理。
|
2月前
|
存储 缓存 Java
大厂面试必看!Java基本数据类型和包装类的那些坑
本文介绍了Java中的基本数据类型和包装类,包括整数类型、浮点数类型、字符类型和布尔类型。详细讲解了每种类型的特性和应用场景,并探讨了包装类的引入原因、装箱与拆箱机制以及缓存机制。最后总结了面试中常见的相关考点,帮助读者更好地理解和应对面试中的问题。
84 4
|
2月前
|
存储 消息中间件 NoSQL
使用Java操作Redis数据类型的详解指南
通过使用Jedis库,可以在Java中方便地操作Redis的各种数据类型。本文详细介绍了字符串、哈希、列表、集合和有序集合的基本操作及其对应的Java实现。这些示例展示了如何使用Java与Redis进行交互,为开发高效的Redis客户端应用程序提供了基础。希望本文的指南能帮助您更好地理解和使用Redis,提升应用程序的性能和可靠性。
50 1
|
2月前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
98 2
|
2月前
|
存储 Java 编译器
Java泛型类型擦除以及类型擦除带来的问题
泛型擦除是指Java编译器在编译期间会移除所有泛型信息,使所有泛型类型在运行时都变为原始类型。例如,`List&lt;String&gt;` 和 `List&lt;Integer&gt;` 在JVM中都视为 `List`。因此,通过 `getClass()` 比较两个不同泛型类型的 `ArrayList` 实例会返回 `true`。此外,通过反射调用 `add` 方法可以向 `ArrayList&lt;Integer&gt;` 中添加字符串,进一步证明了泛型信息在运行时被擦除。
59 2