昨天意外的惊喜了属于,晚课领我们出去聚了次餐!

跟老师聊了很多也喝了许多,迷迷糊糊的但好像压力减轻了些

今天下午又开始了疯狂的学学学模式。

String类型与八大包装类型

String类型

String类型是引用数据类型,他的包路径是:java.lang.String
String类型在底层是一个char数组(Java9开始改为byte数组)
在Java中规定,双引号括起来的都是字符串对象,是不可变的,被放到字符串常量池中。

String对象的创建方式

1.使用双引号""括起来的都是String对象,这种方式创建的对象都是存放在字符串常量池中

2.使用构造方法创建String对象,这种方式创建的对象都是存放在堆内存中

String字符串存储原理

代码如下

内存图如下

通过内存图可以看出使用双引号括起来的字符串都放到 String Table(字符串常量池) 中;使用构造方法创建的字符串都放到了堆内存中。
那么问题来了,在上面的程序中一共创建了多少个String对象?

知道了程序的内存结构,我们来分析一下下面的程序

对以上代码的输出结果为

因为"=="运算符比较的是变量的值,而引用数据类型中存放的值都是对象的内存地址,通过内存图我们可以看出

str1(0x111) == str2(0x111) ----> 内存地址相同,结果为true
str4(0x555) == str5(0x666) ----> 内存地址不相同,结果为false
str1(0x111) == str4(0x555) ----> 内存地址不相同,结果为false

String类型常用方法

比较

获取

转换

String类还有一个静态方法String.valueOf(多类型重载),当该方法参数为Object是会调用该Object的toString()

字符串的拼接

使用字符串连接符"+"进行拼接

由于字符串是不可变的,所以在每次拼接后都会产生新的字符串,这样会占用大量的字符串常量池内存,造成空间浪费。
使用String实例方法concat(String)
调用concat()拼接字符串,方法内部代码执行会产生一个新的String对象
使用StringBuffer或StringBuilder
使用StringBuffer或StringBuilder追加内容,如果追加后不超出StringBuffer或StringBuilder的容量,那么并不会产生新的对象

StringBuffer和StringBuilder

String与StringBuffer区别:
String和StringBuffer底层都是数组(Java9之前是char数组,Java9(包括9)之后是byte数组。),String底层的数组被final修饰,StringBuffer底层的数组没有被final修饰,所以StringBuffer可以扩容,String不能进行扩容


StringBuffer与StringBuilder区别
StringBuffer中方法都被synchronize关键字修饰,表示在多线程环境下运行时安全的,而StringBuilder中的方法没有被synchronize关键字修饰,所以StringBuilder时非线程安全的。 

八大包装类型 

为什么要使用包装类型?

在调用方法时,若方法参数是引用数据类型(Object类型),那么使用基本数据类型是无法传参进去的,所以需要包装类间接传参。

八种基本数据类型对应的八种包装类型都是什么?

八种包装类常用的属性和方法(以Integer为例)

因为八种包装类的方法基本相似,所以通过学习Integer的常用方法可以对其他包装类照葫芦画瓢。

属性

public static final int MIN_VALUE;  -------> 获取int类型的最小值

public static final int MAX_VALUE; -------> 获取int类型的最大值

构造方法

public Integer(int);   -------> 通过一个int类型数据创建一个Integer对象

public Integer(String); -------> 通过一个String类型的数据创建一个Integer对象

 如果构造方法中传入的实参是String类型,在程序运行时可能会出现数值格式化异常——NumberFormatException

实例方法

public int intValue();    -------> 将当前Integer类型转换成int类型

public float floatValue(); -------> 将当前Integer类型对象转换成float类型

对于所有的Number类型对象,都可以任意转换成相应的基本数据类型(byte,short,int,long,float,double) 

静态方法

手动装箱与手动拆箱

自动装箱与自动拆箱(JVM5新特性)

包装类使用算数运算符(+ - * / %)进行算数运算时都会执行自动拆箱动作

整数型常量池

在Java中为了执行效率,在类加载时刻会在方法区中会声明并初始化一个长度为256的Integer静态常量数组,其中存储了范围在[-128,127]中的Integer对象,我们将这个Integer数组为称作整数型常量池

Integer面试题

输出结果为

Stirng、Integer、int类型相互转换