String学习
主要问题:
1.string是如何实现的
string内部存储结构是char数组
2.string有哪些主要的方法
多构造方法:
以string为参数的构造方法
以char数组为参数的构造方法
以stringbuffer为参数的构造方法
以stringbuilder为参数的构造方法
*
equals比较方法
接收object类型的参数,首先用instanceof判断是否是同一类型,不是直接返回false,然后在循环比较(while)每个字符。重写了object的equals方法
compareTo比较方法
也是循环比较,返回正数负数或者0,return char[1] - char[2]。
两个比较方法的不同:
equals可以接收object类型的参数。compareTo只能接受string类型的参数;
equals返回值是布尔类型,compareTo返回值类型是int。
其他方法:
indexOf():查询字符串首次出现的下标位置
lastIndexOf():查询字符串最后出现的下标位置
contains():查询字符串中是否包含另一个字符串
toLowerCase():将字符串全部转化成小写
toUpperCase():将字符串全部转化成大写
length():查询字符串长度
trim():去掉字符串首尾空格
replace():替换字符串中的某些字符
split():分割字符串返回字符串数组
join():把字符串数组转化为字符串
面试经典问题:
1.为什么string类型用final修饰?
用final修饰可以缓存结果(常量池缓存),当在传参是不需要考虑他的值是否会被修改,如果是可变类,有可能需要重新拷贝出一个新的值进行传参,在性能上有一定的损失。
在一个原因就是安全、高效。
2.==和equals有什么区别?
==对于基本数据类型来说,适用于比较“值”是否是相等的,而对于引用类型来说,是用于比较引用地址是否是相等的。
Object的equals方法实现就是==,string重写了object的equals方法,将引用对比改成字符串对比,用来比较两个字符串的值是否相等。
3.string和stringbuffer、stringbuilder有什么区别?
string类型不可变,字符串拼接时效率低。
stringbuffer用synchronize修饰拼接方法,线程安全,但是并发量高的情况下效率低;
stringbuilder线程不安全,并发量高的情况下效率高。
4.string的intern()方法有什么含义?
将该值保存到到常量池。
5.string类在JVM中是如何存储的?编译器对string做了哪些优化?
string两种创建方法:
①:String s1 = “java”;
②:String s2 = new String("java");
这两种创建方法在JVM中存储区域截然不同,s1会现在常量池中寻找值,找到值之后直接返回,找不到则在常量池中创建;s2直接在堆内存中创建新的string对象,调用intern()方法后才会将该值放到常量池中。(JDK1.7之后将永生代换成元空间,把字符串常量池从方法区移到java堆上)
③:String s3 = "ja"+"va";
如果打印s1 == s3,输出结果是true,在JVM编译的时候s3被直接编译成“java”。