自动装箱和拆箱

  • JDK1.5后,Java引入了自动装箱(autoboxing)/拆箱(unboxing)

自动装箱

  • 基本数据类型在需要时自动转化为对象

自动装箱

  • 对象在需要时自动转化为基本数据类型

注意:

  此处的自动是假自动,只是编译器替开发者做了一些事情而已.   也称为编译器蜜糖

实例自动装箱

1      // 界面书写方式
2 Integer baseDataTyeTranslation = 123;
3
4 // 实际编译器替开发的操作
5 Integer baseDataTyeTranslationFact = Integer.valueOf(123);

可以在生成的.class文件中查看

实例自动拆箱

1     // 编译器界面书写方式
2 Integer baseDataTyeTranslation = 123;
3
4 // 编译器界面拆箱
5 int autoBoxingInteger = baseDataTyeTranslation;
6
7 // 实际编译器替开发的操作
8 int autoBoxingIntegerFact = baseDataTyeTranslation.intValue();

可以在生成的.class文件中查看

经典错误自动拆箱1------空指针问题

1     // 初始化类型
2 Integer baseDataTyeTranslation = null;
3
4 // 赋值给基本数据类型
5 int autoBoxingIntegerFact = baseDataTyeTranslation;

报错:

1  Exception in thread "main" java.lang.NullPointerException at com.mr.test.AutoBoxingDemo1.main(AutoBoxingDemo1.java:13) at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.base/java.lang.reflect.Method.invoke(Method.java:564) at com.intellij.rt.execution.application.AppMainV2.main(AppMainV2.java:131)

因为在拆箱的时候,自动调用intValue()方法,而基本数据类型中没有null这个数值,所以,就会报错

解决方案
1     // 初始化类型
2 Integer baseDataTyeTranslation = null;
3
4 if (baseDataTyeTranslation != null) {
5 // 赋值给基本数据类型
6 int autoBoxingIntegerFact = baseDataTyeTranslation;
7 }

经典错误自动拆箱2--------缓存问题

1      // 初始化类型
2 Integer baseDataTyeTranslation1 = Integer.valueOf(-128);
3
4 Integer baseDataTyeTranslation2 = Integer.valueOf(-128);
5
6 System.out.println(baseDataTyeTranslation1 == baseDataTyeTranslation2);

返回结果是true,'=='比较的是对象的索引,而此处结果却是true,在[-128,127]区间的数,在创建对象的时候,是走缓存的,缓存时,先检测范围,如果是缓存范围内,就调用缓存对象,不是范围内,就新建对象。

源码:

1、-128-127走缓存

2、缓存中数据

3、在范围内,加入缓存中

改写方式:

 1 public class AutoBoxingDemo1{
2
3 public static void main(String[] args) {
4
5
6 // 初始化类型
7 Integer baseDataTyeTranslation1 = AutoBoxingDemo1.valueOf(-128);
8
9 Integer baseDataTyeTranslation2 = AutoBoxingDemo1.valueOf(-128);
10
11 System.out.println(baseDataTyeTranslation1 == baseDataTyeTranslation2);
12
13
14 }
15
16
17 public static Integer valueOf(int i) {
18 return new Integer(i);
19 }
20 }

JDK源码阅读-------自学笔记(十)(java.lang.Integer包装类初探)的更多相关文章

  1. JDK源码阅读-------自学笔记(一)(java.lang.Object重写toString源码)

    一.前景提要 Object类中定义有public String toString()方法,其返回值是 String 类型. 二.默认返回组成 类名+@+16进制的hashcode,当使用打印方法打印的 ...

  2. JDK源码阅读-------自学笔记(二十五)(java.util.Vector 自定义讲解)

    Vector 向量 Vector简述 1).Vector底层是用数组实现的List 2).虽然线程安全,但是效率低,所以并不是安全就是好的 3).底层大量方法添加synchronized同步标记,sy ...

  3. JDK源码阅读-------自学笔记(五)(浅析数组)

    一.数组基础 1.定义和特点 数组也可以看做是对象,数组变量属于引用类型,数组中每个元素相当于该队形的成员变量,数组对象存储在堆中. 2.初始化数组 常用类初始化 // 整型初始化 int[] int ...

  4. JDK源码阅读-------自学笔记(二十四)(java.util.LinkedList 再探 自定义讲解)

    一.实现get方法 1.一般思维实现思路 1).将对象的值放入一个中间变量中. 2).遍历索引值,将中间量的下一个元素赋值给中间量. 3).返回中间量中的元素值. 4).示意图 get(2),传入角标 ...

  5. JDK源码阅读-DirectByteBuffer

    本文转载自JDK源码阅读-DirectByteBuffer 导语 在文章JDK源码阅读-ByteBuffer中,我们学习了ByteBuffer的设计.但是他是一个抽象类,真正的实现分为两类:HeapB ...

  6. JDK源码阅读(三):ArraryList源码解析

    今天来看一下ArrayList的源码 目录 介绍 继承结构 属性 构造方法 add方法 remove方法 修改方法 获取元素 size()方法 isEmpty方法 clear方法 循环数组 1.介绍 ...

  7. JDK源码阅读(一):Object源码分析

    最近经过某大佬的建议准备阅读一下JDK的源码来提升一下自己 所以开始写JDK源码分析的文章 阅读JDK版本为1.8 目录 Object结构图 构造器 equals 方法 getClass 方法 has ...

  8. 利用IDEA搭建JDK源码阅读环境

    利用IDEA搭建JDK源码阅读环境 首先新建一个java基础项目 基础目录 source 源码 test 测试源码和入口 准备JDK源码 下图框起来的路径就是jdk的储存位置 打开jdk目录,找到sr ...

  9. JDK源码阅读-FileOutputStream

    本文转载自JDK源码阅读-FileOutputStream 导语 FileOutputStream用户打开文件并获取输出流. 打开文件 public FileOutputStream(File fil ...

  10. JDK源码阅读-FileInputStream

    本文转载自JDK源码阅读-FileInputStream 导语 FileIntputStream用于打开一个文件并获取输入流. 打开文件 我们来看看FileIntputStream打开文件时,做了什么 ...

随机推荐

  1. 重磅官宣 | 第二届OpenHarmony技术峰会,邀您共启智联未来

      "下一个技术未来在哪里?" 11月4日  技术大咖齐聚北京为你解答 一场主论坛+八大开源领域分论坛 探究终端操作系统十大技术挑战方向 与全球开源操作系统技术领袖.实践专家.一线 ...

  2. 如何使用DevEco Studio创建Native C++应用

    简介 本篇主要介绍如何使用DevEco Studio for OpenAtom OpenHarmony (以下简称"OpenHarmony")创建一个Native C++应用.应用 ...

  3. 构筑智能未来的开源 .Net AI知识库/智能体项目

    在这个信息爆炸的时代,我们如何快速准确地从汪洋大海的数据中抽取真正有价值的知识呢?AntSK,一个基于.NET开发的人工智能知识库和智能体项目,似乎给出了一个新颖的答案.今天,就让我们一起深入了解An ...

  4. Java+HTML预习笔记_20140610

    1.HTML <img> 标签 HTML <img> 标签 实例 在下面的例子中,我们在页面中插入一幅 W3School 的工程师在上海鲜花港拍摄的郁金香照片: <img ...

  5. redis 简单整理——pipeline[十]

    前言 简单整理一下pipeline. 正文 1)发送命令 2)命令排队 3)命令执行 4)返回结果 其中1)+4)称为Round Trip Time(RTT,往返时间). pipeline它能将一组R ...

  6. Redis工具类,不用框架时备用

    redis.hostName=127.0.0.1 redis.port=6379 redis.database=3 redis.timeout=15000 redis.usePool=true red ...

  7. NodeJs进阶开发、性能优化指南

    相信对于前端同学而言,我们去开发一个自己的简单后端程序可以借助很多的nodeJs的框架去进行快速搭建,但是从前端面向后端之后,我们会在很多方面会稍显的有些陌生,比如性能分析,性能测试,内存管理,内存查 ...

  8. Git中 fork, clone,branch

    一.是什么 fork fork,英语翻译过来就是叉子,动词形式则是分叉,如下图,从左到右,一条直线变成多条直线 转到git仓库中,fork则可以代表分叉.克隆 出一个(仓库的)新拷贝 包含了原来的仓库 ...

  9. 使用 Docker Compose 安装 APISIX

    1.基本概念 APISIX 是 Apache 下的一款云原生的 API 网关,支持全生命周期的 API 管理,在应用中可以作为所有 API 调用的统一入口. APISIX 有一些基础概念如下: Ups ...

  10. 《c#高级编程》第2章C#2.0中的更改(三)——迭代器

    一.概念 C#迭代器(Iterator)是一种特殊类型的方法,它使得在使用循环遍历数据集合时更加简单和有效.使用迭代器可以通过简单地定义迭代器方法来自动实现枚举器模式. 当您需要访问一个数据集合中的每 ...