概述:

在Java中存在一些基本数据类型,这些基本数据类型变量,不能像其他对象一样调用方法,属性....

一些情况下带来一些问题,包装类就是为了解决这个问题而出现

包装类可以使得这些基础数据类型,拥有对象的能力

包装类与基础类型的对应关系

特点:

  • 包装类都是final修饰无法继承
  • 数字类型的父类都是Number
  • 当包装类作为类属性时,其默认值都为Null

拆箱与装箱

拆箱指的是将基础数据类型包装为对象,拆箱与之相反

  • 自动装箱

    将基础数据类型直接赋值给对应包装类的引用变量,系统会自动进行装箱操作

    Integer a = 10;
  • 自动拆箱

    Integer a = new Integer(10);
    int b = a;
  • 手动拆箱

    Integer a = new Integer(10);
    int b = a.intValue();
  • 手动装箱/装箱

    Integer as = new Integer(10);//装箱
    Integer.valueOf(1);//装箱
    Float.valueOf(1.1);//装箱
    .... as.intValue();//拆箱

    通常我们不需要进行手动拆装箱

自动拆箱的时机

1.将包装类型变量直接赋值给对应基础类型时,系统会自动进行拆箱操作

2.当要访问这个对象的真实数据值时会进行自动拆箱,例如要输出对象的值

3.当要对包装类的实际值进行数学运算时,会自动拆箱,例如比较大小

需要注意的是,当使用判断是否相等时,符号任意一边是基础数据类型另外一边都会自动拆箱(不会出问题),但如果两边都是包装类型则会比较对象引用是否相同(可能产生问题)
Integer i1 = new Integer(10);
Integer i2 = new Integer(10);
System.out.println(i1 == i2); //结果为false

字符串与包装类互相转换

在开发中经常需要将基础数据类型与字符串类型相互转换

//我们可以使用包装类提供的valueof()方法来将字符串转为对象的包装类
System.out.println(Float.valueOf("1.1ff"));
System.out.println(Boolean.valueOf("true"));
//相反的String提供了静态方法valueOf() 其他任意类型转换为字符串类型 Object表示所有类均可,包括包装类
System.out.println(String.valueOf('c'));
System.out.println(String.valueOf(true));

对象常量池

Java虚拟机会默认将一些简单的字面量对象放到常量池中,来减少频繁的内存操作;是一种优化机制;

测试代码:

Long s1 = Long.valueOf(127l);
Long s2 = 127l;
Long s3 = new Long(127l);
System.out.println(s1 == s2); //true
System.out.println(s1 == s3); //false String st1 = "常量池噢噢噢噢";
String st2 = "常量池噢噢噢噢";
String st3 = new String("常量池噢噢噢噢");
System.out.println(st1 == st2); //true
System.out.println(st1 == st3); //false Boolean b1 = true;
Boolean b2 = true;
Boolean b3 = new Boolean(true);
System.out.println(b1 == b2); //true
System.out.println(b1 == b3); //false Character c1 = 'a';
Character c2 = 'a';
Character c3 = new Character('a');
System.out.println(c1 == c2); // true
System.out.println(c1 == c3); // false Float f1 = 1.0f;
Float f2 = 1.0f;
Float f3 = new Float(1.0f);
System.out.println(f1 == f2);//flase
System.out.println(f1 == f3);//flase Double d1 = 1d;
Double d2 = 1d;
Double d3 = new Double(1d);
System.out.println(d1==d2);//flase
System.out.println(d1==d3);//flase
  • String类型的所有字面量都会进入常量池
  • Byte Short Integer Long 四种类型字面量在大于等于 -128 且小于等于127 时对象将进入常量池
  • Character 类型 不能为负数,字面量大于等于0 且 小于等于127时对象将进入常量池
  • Boolean类型 两个字面量都会进入常量池
  • Float 和Double 类型 不会进入常量池

强调:

字面量的意思是说,在编译期间就直接指定了实际值,非常明确的数据

这意味着当我们没有使用字面量而是使用 new关键字时,对象将直接进入堆区而不会进入常量池 ,请看下面的例子:

Integer a1 = new Integer(10);
Integer a2 = new Integer(10);
System.out.println(a1 == a2); //false

一旦出现了new 则必然要开辟新内存空间,无法利用常量池了!因此建议在代码中尽量使用字面量避免使用new;

补充说明:

这些包装类,以及String类提供的静态方法valueOf();都会先访问常量池,而不是立即new, 所以使用字面量或者valueOf方法都可以利用常量池;

注意:

基础数据类型不需要缓存到常量池中因为基础数据类型不存在引用这么一说,就是一个实际的值随方法存储在栈区;

Java - 包装类 常量池的更多相关文章

  1. Java字符串常量池是什么?为什么要有这种常量池?

    简单介绍 Java中的字符串常量池(String Pool)是存储在Java堆内存中的字符串池.我们知道String是java中比较特殊的类,我们可以使用new运算符创建String对象,也可以用双引 ...

  2. Java字符串常量池及字符串判等解析

    一.理解"=="的含义 "=="常用于两个对象的判等操作,在Java中,"=="主要有以下两种用法: 1.基础数据类型:比较的是他们的值是否 ...

  3. Java基础-常量池

    在class文件中,“常量池”是最复杂也最值得关注的内容. Java是一种动态连接的语言,常量池的作用非常重要,常量池中除了包含代码中所定义的各种基本类型(如int.long等等)和对象型(如Stri ...

  4. java基础知识回顾之---java String final类 容易混淆的java String常量池内存分析

    /** *   栈(Stack) :存放基本类型的变量数据和对象的引用,但对象本身不存放在栈中,而是存放在堆(new 出来的对象)或者常量池中(字符串常量对象存放  在常量池中). 堆(heap):存 ...

  5. 【转】Error,java对常量池来说字符串xxx的UTF8表示过长的解决及其理解

    做项目,客户端这里自己模拟json数据时,一时没忍住搞得json字符串太长了(idea上大概有600多行吧),这个问题就蹦出来了.老方法直接google.百度然后看到一堆有关String 字符串常量池 ...

  6. Java字符串常量池

    JVM为了减少字符串对象的重复创建,维护了一个特殊的内存,这段内存被称为字符串常量池. Java中字符串对象的创建有两种形式:一种是字面量形式,String str = "a":一 ...

  7. Java String 常量池理解

    String:字符串常量池 作为最基础的引用数据类型,Java 设计者为 String 提供了字符串常量池以提高其性能,那么字符串常量池的具体原理是什么,我们带着以下三个问题,去理解字符串常量池: 字 ...

  8. java字符串常量池——字符串==比较的一个误区

    转自:https://blog.csdn.net/wxz980927155/article/details/81712342   起因 再一次js的json对象的比较中,发现相同内容的json对象使用 ...

  9. 关于java字符串常量池

    今天发现一个好玩的东西 public static void main(String[] args)    {        String str1 = new StringBuilder(" ...

随机推荐

  1. C++生成完全二叉树

    C++生成完全二叉树 2019-12-20 By Gauss 1.背景介绍 完全二叉树是效率很高的数据结构,完全二叉树是由满二叉树而引出来的.对于深度为K的,有n个结点的二叉树,当且仅当其每一个结点都 ...

  2. js反爬学习(一)谷歌镜像

    1. url:https://ac.scmor.com/ 2. target:如下链接 3. 过程分析: 3.1 打开chrome调试,进行元素分析.随便定位一个“现在访问” 3.2 链接不是直接挂在 ...

  3. 新人踩坑的一天——springboot注入mapper时出现java.lang.NullPointerException: null

    来公司的第二周接到了定时任务的开发需求:每天早上十点发送用户报表邮件 .校招新人菜鸟没做过这玩意有些懵(尴尬)于是决定分步写,从excel导出->邮件发送->定时器实现->mappe ...

  4. SpringCloud-使用熔断器仪表盘监控熔断

    场景 SpringCloud-使用熔断器防止服务雪崩-Ribbon和Feign方式(附代码下载): https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/ ...

  5. vue & nodejs jwt 的基于token身份验证

    现在比较流行的验证方式,是带着token的登录验证 原理 1. 登陆时,客户端发送用户名密码 2. 服务端验证用户名密码是否正确,校验通过就会生成一个有时效的token串,发送给客户端 3. 客户端储 ...

  6. 升级sharepoint2013遇到的坑

    现在要将sharepoint2010,ProjectServer2010升级到2016的版本,需要先升级到2013的版本. 按照官方文档,瞎搞将sharepoint2010升级到2013的版本,中间出 ...

  7. RabbitMQ 备份交换机(alternate-exchange)介绍

    RabbitMQ之备份交换机(alternate-exchange) 1.备份交换器,AlternateExchange(AE) 备份交换器是为了实现没有路由到队列的消息,声明交换机的时候添加属性al ...

  8. HttpRunner学习3--extract提取数据和引用

    前言 在HttpRunner中,我们要想从当前 HTTP 请求的响应结果中提取参数,可以通过 extract 关键字来实现. 本人环境:HttpRunner V1.5.8 测试场景 在这里,我将以一个 ...

  9. 从头学pytorch(一):数据操作

    跟着Dive-into-DL-PyTorch.pdf从头开始学pytorch,夯实基础. Tensor创建 创建未初始化的tensor import torch x = torch.empty(5,3 ...

  10. 1、nio说明 和 对比bio

    nio和bio的区别 bio: 面向流的. 单向的. 阻塞的,这也是b这个的由来. nio: 面向块的.(buffer) 双向的. 非阻塞的.同步的编程方式.是一种select模型 nio编程的常规步 ...