1.String概述
字符串 ""引起来表示
- 声明为final 不可被继承
- String实现了Serializable接口 表示字符串支持序列
- 实现了comparable接口 表示String可比较大小
- String内部定义final char[] value用于存储字符串数据
- 通过字面量方式和new字符串赋值 创建 字面量创建的字符串在常量值
2.String的不可变性
String不可变性 对于现有字符串的任何修改 都是新造字符串
如果s1和s2 指向同一个内存空间 如果其中一个变量修改了 另一个也会修改 这是不合理的
3.String实例化
字面量 / new + 构造器
3.1 String在内存创建了两个对象 一个是堆空间new结构 另一个是char[] 对应常量池的数据
4.字符串拼接赋值的对比
inter方法:将常量池的数据赋值给变量
final 修饰拼接
本文链接:字符串拼接对比情况
5.String常用方法
6.1String、StringBuffer、StringBuilder异同
相同:都是存储字符串的 都是char数组存的
String:不可变的字符序列 每次新加都是新键字符串
StringBuffer:可变的字符序列,线程安全的,效率低
每次新加都是在原有基础上添加 如果不够会扩容
StringBuilder:可变的字符序列,JDK5.0新增的,线程不安全,效率高
StringBuffer sb1 = new StringBuffer();// 底层创建长度为16的数组
每次创建空16个+现有字符串长度
6.3 String与基本类型 包装和字符数组/字节数组之间的转换
parsexxx valueOf toChartArray getChars(begin,end,char[])
getBytes() String(gbks,"character)
6.5与StringBuffer、StringBuilder之间的转换 调用二者构造器
new StringBuffer(String) new StringBuilder(String)
new String(bf/bi) / toString()
7 JVM中字符串常量池存放位置说明
jdk1.6(jdk6.0 java 6.0) 存放在永久区
jdk1.7 存放在堆空间
jdk1.8 存放在方法区(元空间)
8.常见算法题目的考察
9.StringBuffer StringBuilder的内存解析
StringBUffer为例
//1.底层创建了一个长度16的数组
StringBuffer s1 = new StringBuffer(“abc”); //new char[]{‘a’,‘b’,‘c’}
System.out.println(s1.length());//3 总体空间为s1.length+16
//2.扩容问题
如果数据底层存不下了,就需要扩容数组
默认情况,扩容为原来数组的2倍+2,同时将数组原来的元素赋值到新的数组
10.StringBuffer StringBuilder String三者的执行效率
string > StringBuilder > StringBuffer
10.StringBuffer、StringBuilder常用方法
StringBuffer
增 append(xxx)
删:delete(xxx)
改:setCharAr(int n,char ch) / replace(int start,int end,String str)
查:charAt(int n)
插:insert(int offset,int i)
长度:length
遍历:for + charAt / toString