我是南城余!阿里云开发者平台专家博士证书获得者!
欢迎关注我的博客!一同成长!
一名从事运维开发的worker,记录分享学习。
专注于AI,运维开发,windows Linux 系统领域的分享!
本章节对应知识库:
常用类和基础API (yuque.com)
尚硅谷_宋红康_String的内存结构.pptx
Java API查看 参考网站
Java SE 文档 — API 和文档 | Oracle 中国
Java 8 中文版 - 在线API手册 - 码工具
方法参数的值传递机制
基本数据类型传递的是数值,引用数据类型传递的是地址值
String类
public final class String
implements java.io.Serializable, Comparable<String>, CharSequence
final :凡是final修饰的,不可被修改,所以String是不可被继承的
Serializable:可序列化的接口,凡是实现此接口的类的对象就可以通过网络或在本地流进行数据的传输
Comparable:凡是实现此接口的类,其对象都可以比较大小
字符串常量的存储位置
>字符串都存储在字符串常量池(StringTable)中
>字符串常量池不允许存放两个相同的字符串常量
>字符串常量池,在不同的jdk版本中,存放的位置不同
jdk7之前:存放在方法区
jdk7及以后:存放在堆空间中
String的不可变性理解
》当对字符串变量重新赋值时,需要重新指定一个字符串常量的位置进行赋值,不能在原有的位置修改
》当对现有字符串进行拼接时,需要重新开辟空间保存拼接后的字符串,不能在原有的位置修改
》当调用字符串的replace()替换现有的某个字符时,需要重新可开票空间保存修改以后的字符串,不能在原有的位置修改
String s2 = new String("hello");在内存中创建了两个对象
一个是堆空间中new的对象,另一个是字符串常量池中生成的字面量
String的连接操作:+
情况1:常量+常量:结果仍然存储在字符串常量池中,返回此字面量的地址 注:此时的常量可能是字面量或者final修饰的常量
情况2 : 常量 + 变量 或 变量+ 变量 :都会通过new的方式创建一个新的字符串,返回堆空间中此字符串对象的地址
情况3 :调用字符串的intern():返回的是字符串常量池中的字面量的地址
concat():不管是常量调用此方法,还是变量调用,同样不管是常量还是变量,总之,调用完,都返回一个新new的对象
基本数据类型与引用数据类型间的转换
//基本数据类型转换引用数据类型
int num = 10;
//方式1:
String s1 = num + "";
//方式2: valueOf()
String s2 = String.valueOf(num);
//引用数据类型转换基本数据类型:调用包装类的parssexxx(String str)
String s3 = "11230";
int num1 = Integer.parseOf(s3);
编码、解码
编码:字符、字符串——>字节、字节数组(对应着编码集)
解码:字节、字节数组——>字符、字符串(对应着解码集)
StringBuffer和StringBuilder中常用的方法
增:
append()
删:
delete(int start, int end)
deleteCharAt(int index)
改:
setCharAt(int index,char c)
replace(int start,int end,String str)
查:
charAt(int index)
插:
insert(int index,xx)
长度:
length()
String、StringBuffer、StringBulider使用场景
在Java中,String、StringBuffer和StringBuilder是处理字符串的常用类。它们之间有一些重要的区别,包括线程安全性和可变性。这里将解释每个类以及它们的使用场景。
- String:String类是不可变的,这意味着一旦创建了一个字符串,就不能更改它的值。如果尝试改变字符串中的某些字符,那么会创建一个新的字符串。因此,当需要多个修改字符串的操作时,String可能不是最佳选择,因为它会产生大量的中间字符串。例如,在一系列字符串连接操作中使用String会导致大量不必要的字符串创建和垃圾回收。
- StringBuffer:StringBuffer是可变的,可以在原地修改字符串,而不会创建新的字符串。因此,StringBuffer适用于需要频繁修改字符串的场景,例如在字符串拼接、字符串替换、字符串截取等操作中。此外,StringBuffer是线程安全的,这意味着在多线程环境中使用StringBuffer是安全的。
- StringBuilder:StringBuilder和StringBuffer类似,都是可变的,可以在原地修改字符串。然而,StringBuilder不是线程安全的。因此,在单线程环境中,StringBuilder通常比StringBuffer更快,因为它没有进行线程安全的同步操作。因此,如果不需要考虑多线程环境,建议使用StringBuilder而不是StringBuffer。
总结起来,String、StringBuffer和StringBuilder的使用场景如下:
- 如果需要一个不可变的字符串,可以使用String。
- 如果需要频繁修改字符串并且需要线程安全,可以使用StringBuffer。
- 如果需要频繁修改字符串但是在单线程环境中,可以使用StringBuilder。
日期、时间API
jdk8之前的
》System的currentTimeMills()
》两个Date的使用
》SimpleDateFormat用于格式化、解析
》Calendar日历类的使用
jdk8
》LocalDate、LocalTime、LocalDateTime—》类似于Calendar
》Instant——》类似于Date
》DateTimeFormater——》类似于SimpleDateFormat
Java比较器
自然排序:实现Comparaable接口的方式
》具体类A实现Comparable接口
》重写Comparable接口的compareTo(object obj)方法,在此方法中指明比较类A对象的大小标准
》创建类A的多个实例,进行大小的比较或排序
定制排序:实现Comparator接口
》创建一个实现Comparator接口的实现类A
》实现类A要求重写Comparator接口中的抽象方法compare(Object o1,Object o2),在此方法中指明要比较大小的对象的大小关系
》创建此实现类A的对象,并将此对象传入相关方法的参数位置即可。
两种接口对比
自然排序:单一的,唯一的 对应的接口是Comparable,对应的抽象方法compareTo(Object obj)
定制排序:灵活的,多样的,对应的接口是Comparator,对应的抽象方法compare(Object obj1,Object obj2)
sort()方法排序
Java中的sort()方法是用于对数组或列表进行排序的。它来自java.util.Arrays类或java.util.Collections类,可以对基本数据类型和对象数组进行排序。
具体来说,Java中的sort()方法使用一种称为归并排序的稳定排序算法,该算法是采用分治法的一种高效、稳定、简单的排序算法。它将待排序的数据分割成若干个子序列,分别进行排序,最终合并成一个有序的序列。
sort()方法的使用方式如下:
- 对于基本数据类型数组,可以使用Arrays.sort()方法进行排序,例如:
int[] arr = {3, 1, 4, 1, 5, 9};
Arrays.sort(arr);
- 对于对象数组或列表,可以使用Collections.sort()方法进行排序,例如:
List<String> list = Arrays.asList("C", "A", "B");
Collections.sort(list);
需要注意的是,如果要自定义排序规则,可以实现Comparator接口,并将其作为sort()方法的第二个参数传递。例如,如果要按照字符串长度进行排序,可以这样写:
List<String> list = Arrays.asList("C", "ABC", "AB", "A");
Collections.sort(list, new Comparator<String>() {
@Override
public int compare(String s1, String s2) {
return s1.length() - s2.length();
}
});