1.java中compareToIgnoreCase大
2.还是源码源码搞不明白compareTo()方法
java中compareToIgnoreCase大
在Java中,`String`类的源码源码`compareToIgnoreCase`方法提供了一种忽略大小写的字符串比较方式。这个方法的源码源码核心逻辑在于,它首先将两个字符串中的源码源码桃源码头到大理公交路线字符逐个进行比较,如果遇到不同字符,源码源码会将它们转换为大写或小写后再进行比较。源码源码只有当所有字符都相同或者都转换为同一形式后,源码源码才会继续下一个字符。源码源码如果在整个字符串长度范围内找不到相同的源码源码字符,那么比较将基于字符串的源码源码长度差异。这个方法在`CaseInsensitiveComparator`类中实现,源码源码math.sin源码其源码如下:
String类中的源码源码compareToIgnoreCase方法实现是通过逐字符比较,忽略大小写的源码源码。它首先计算两个字符串的源码源码长度,然后从第一个字符开始比较,源码源码如果字符不同,漂亮k线源码先将两个字符转换为大写或小写,再次比较。如果仍然不同,再转换为小写,然后比较ASCII值。扎金蛋php源码若在字符串长度范围内未找到相同的字符,则以字符串长度的差异作为结果返回。这种方法的代码结构清晰,易于理解。
总的看vip视频 源码来说,`compareToIgnoreCase`方法是通过字符级别的转换和比较,实现了在比较字符串时忽略大小写的逻辑。
还是搞不明白compareTo()方法
1.先回答得到的返回值是负整数、零或正整数,和排序问题怎么联系:
返回这3种值对我们来说或许没有意义,但是这3个值告诉底层如何判断2个对象的大小,至于排序,我们是通过Collections.sort和Arrays.sort进行,而这2个方法在底层实现时,使用到了object1.compareTo(object2)这种方法进行判断谁大谁小,从而调整数组,最终给你返回有序的集合.注:你可以参考源代码,所有的排序都要用到调用的是Arrays.mergeSort(Object[] src,Object[] dest,int low,int high,int off).
2.Comparable还有Comparator的使用:当你自己写类时,如果希望这个类能按照自己的意愿进行排序,你就实现Comparable接口,你就是只要告诉底层怎么判断大小(即compareTo()),然后想排序,就是用Collections.sort(List list)即可;
而Comparator的使用:强行对某个对象 collection 进行整体排序,而集合里的对象可以是没有实现Comparable接口的对象,也可以是实现了Comparable接口的对象,使用这个排序器可以改变默认的排序时使用比较大小的方法,这时候底层进行排序就不再是用默认的自然排序,在底层对集合进行排序将不再是用Arrays.mergeSort(Object[] src,Object[] dest,int low,int high,int off),而是是用Arrays.mergeSort(Object[] src,Object[] dest,int low,int high,int off,Comparator c),比较大小则是用了c.compare(dest[j-1], dest[j])。