1.TreeMap就这么简单【源码剖析】
2.ComparableåComparatorçåºå«
3.java中compareToIgnoreCase大
4.java的源码Comparable和Comparator区别
5.java-增强版Comparator进行集合排序null异常处理
6.public static <T> int binarySearch(List<? extends T> list, T key, Comparator<? super T> c)
TreeMap就这么简单【源码剖析】
本文主要讲解TreeMap的实现原理,使用的源码是JDK1.8版本。
在开始之前,源码建议读者具备一定的源码数据结构基础知识。
TreeMap的源码实现主要通过红黑树和比较器Comparator来保证元素的有序性。如果构造时传入了Comparator对象,源码dapp源码查看则使用Comparator的源码compare方法进行元素比较。否则,源码使用Comparable接口的源码compareTo方法实现自然排序。
TreeMap的源码核心方法有put、get和remove等。源码put方法用于插入元素,源码同时会根据Comparator或Comparable对元素进行排序。源码get方法用于查找指定键的源码值,remove方法则用于删除指定键的源码鱼刺类多线程源码元素。
遍历TreeMap通常使用EntryIterator类,该类提供了按顺序遍历元素的方法。TreeMap的遍历过程基于红黑树的结构,通过查找、比较和调整节点来实现。
总之,TreeMap是一个基于红黑树的有序映射集合,其主要特性包括元素的有序性、高效的时间复杂度以及灵活的比较方式。在设计和实现需要有序映射的数据结构时,TreeMap是一个不错的选择。
如有错误或疑问,欢迎在评论区指出,让我们共同进步。自响应式音乐源码
请注意,上述HTML代码片段经过了精简和格式调整,保留了原文的主要内容和结构,但为了适应HTML格式并删除了不相关的内容(如标题、关注转发等),在字数控制上也有所调整。
ComparableåComparatorçåºå«
comparatoræ¥å£ä¸Comparableæ¥å£çåºå«
1. Comparator å Comparable ç¸åçå°æ¹
ä»ä»¬é½æ¯javaçä¸ä¸ªæ¥å£, 并ä¸æ¯ç¨æ¥å¯¹èªå®ä¹çclassæ¯è¾å¤§å°ç,
ä»ä¹æ¯èªå®ä¹class: å¦ public class Person{ String name; int age }.
å½æ们æè¿ä¹ä¸ä¸ªpersonList,éé¢å å«äºperson1, person2, persion3....., æ们ç¨Collections.sort( personList ), æ¯å¾ä¸å°é¢æçç»æç. è¿æ¶è¯å®æ人è¦é®, é£ä¸ºä»ä¹å¯ä»¥æåºä¸ä¸ªå符串listå¢:
å¦ StringList{ "hello1" , "hello3" , "hello2"}, Collections.sort( stringList ) è½å¤å¾å°æ£ç¡®çæåº, é£æ¯å 为 String è¿ä¸ªå¯¹è±¡å·²ç»å¸®æ们å®ç°äº Comparableæ¥å£ , æ以æ们ç Person å¦ææ³æåº, ä¹è¦å®ç°ä¸ä¸ªæ¯è¾å¨ã
2. Comparator å Comparable çåºå«
Comparable
Comparable å®ä¹å¨ Personç±»çå é¨:
public class Persion implements Comparable { ..æ¯è¾Personç大å°..},
å 为已ç»å®ç°äºæ¯è¾å¨,é£ä¹æ们çPersonç°å¨æ¯ä¸ä¸ªå¯ä»¥æ¯è¾å¤§å°ç对象äº,å®çæ¯è¾åè½åStringå®å ¨ä¸æ ·,å¯ä»¥éæ¶éå°çæ¿æ¥æ¯è¾å¤§å°,å 为Personç°å¨èªèº«å°±æ¯æ大å°ä¹åçãCollections.sort(personList)å¯ä»¥å¾å°æ£ç¡®çç»æã
Comparator
Comparator æ¯å®ä¹å¨Personçå¤é¨ç, æ¤æ¶æ们çPersonç±»çç»æä¸éè¦æä»»ä½åå,å¦
public class Person{ String name; int age },
ç¶åæ们å¦å¤å®ä¹ä¸ä¸ªæ¯è¾å¨:
public PersonComparator implements Comparator() { ..æ¯è¾Personç大å°..},
å¨PersonComparatoréé¢å®ç°äºæä¹æ¯è¾ä¸¤ä¸ªPersonç大å°. æ以,ç¨è¿ç§æ¹æ³,å½æ们è¦å¯¹ä¸ä¸ª personListè¿è¡æåºçæ¶å, æ们é¤äºäºè¦ä¼ épersonListè¿å», è¿éè¦æPersonComparatorä¼ éè¿å»,å 为æä¹æ¯è¾Personç大å°æ¯å¨PersonComparatoréé¢å®ç°ç, å¦:
Collections.sort( personList , new PersonComparator() ).
3. Comparator å Comparable çå®ä¾
Comparable:
å®ç°Comparableæ¥å£è¦è¦çcompareToæ¹æ³, å¨compareToæ¹æ³éé¢å®ç°æ¯è¾ï¼
public class Person implements Comparable {
String name;
int age
public int compareTo(Person another) {
int i = 0;
i = name.compareTo(another.name); // 使ç¨å符串çæ¯è¾
if(i == 0) { // å¦æååä¸æ ·,æ¯è¾å¹´é¾, è¿åæ¯è¾å¹´é¾ç»æ
return age - another.age;
} else {
return i; // ååä¸ä¸æ ·, è¿åæ¯è¾ååçç»æ.
}
}
}
è¿æ¶æ们å¯ä»¥ç´æ¥ç¨ Collections.sort( personList ) å¯¹å ¶æåºäº.
Comparator:
å®ç°Comparatoréè¦è¦ç compare æ¹æ³ï¼
public class Person{
String name;
int age
}
class PersonComparator implements Comparator {
public int compare(Person one, Person another) {
int i = 0;
i = one.name.compareTo(another.name); // 使ç¨å符串çæ¯è¾
if(i == 0) { // å¦æååä¸æ ·,æ¯è¾å¹´é¾,è¿åæ¯è¾å¹´é¾ç»æ
return one.age - another.age;
} else {
return i; // ååä¸ä¸æ ·, è¿åæ¯è¾ååçç»æ.
}
}
}
Collections.sort( personList , new PersonComparator()) å¯ä»¥å¯¹å ¶æåº
4:æ»ç»
两ç§æ¹æ³åæä¼å£, ç¨Comparable ç®å, åªè¦å®ç°Comparable æ¥å£ç对象ç´æ¥å°±æ为ä¸ä¸ªå¯ä»¥æ¯è¾ç对象,ä½æ¯éè¦ä¿®æ¹æºä»£ç , ç¨Comparator ç好å¤æ¯ä¸éè¦ä¿®æ¹æºä»£ç , èæ¯å¦å¤å®ç°ä¸ä¸ªæ¯è¾å¨, å½æ个èªå®ä¹ç对象éè¦ä½æ¯è¾çæ¶å,ææ¯è¾å¨å对象ä¸èµ·ä¼ éè¿å»å°±å¯ä»¥æ¯å¤§å°äº, 并ä¸å¨Comparator éé¢ç¨æ·å¯ä»¥èªå·±å®ç°å¤æçå¯ä»¥éç¨çé»è¾,ä½¿å ¶å¯ä»¥å¹é ä¸äºæ¯è¾ç®åç对象,é£æ ·å°±å¯ä»¥èçå¾å¤éå¤å³å¨äºã
java中compareToIgnoreCase大
在Java中,`String`类的`compareToIgnoreCase`方法提供了一种忽略大小写的字符串比较方式。这个方法的核心逻辑在于,它首先将两个字符串中的字符逐个进行比较,如果遇到不同字符,会将它们转换为大写或小写后再进行比较。只有当所有字符都相同或者都转换为同一形式后,才会继续下一个字符。android源码禁止横竖屏如果在整个字符串长度范围内找不到相同的字符,那么比较将基于字符串的长度差异。这个方法在`CaseInsensitiveComparator`类中实现,其源码如下:
String类中的compareToIgnoreCase方法实现是通过逐字符比较,忽略大小写的。它首先计算两个字符串的长度,然后从第一个字符开始比较,如果字符不同,先将两个字符转换为大写或小写,再次比较。如果仍然不同,再转换为小写,然后比较ASCII值。若在字符串长度范围内未找到相同的电话簿 asp源码字符,则以字符串长度的差异作为结果返回。这种方法的代码结构清晰,易于理解。
总的来说,`compareToIgnoreCase`方法是通过字符级别的转换和比较,实现了在比较字符串时忽略大小写的逻辑。
java的Comparable和Comparator区别
Java编程时,有时会用到`Comparable`和`Comparator`来实现数据的排序。它们都有比较的用途,但有明显的差异,我们先从基础和使用场景开始探讨。
### 基础对比
`Comparable`与`Comparator`都属于接口类型,但前者属于`java.lang`包下,后者则位于`java.util`包中。
### 方法对比
`Comparable`提供了`compareTo`方法,用以比较对象之间的大小关系。而`Comparator`提供了`compare`方法,通常用于对比对象进行排序。`compareTo`和`compare`方法的基本用途相似,但后者更通用,可以为不同类型的对象提供比较逻辑。
### 内部与外部比较器
`Comparable`可以被视为一个对象内部的比较机制,它主要用于实现数据类型的自然排序规则。反之,`Comparator`作为外部比较器,通常用于更复杂或特定的比较逻辑,如排序算法。
### 实现与使用场景
使用`Comparable`时,通常需将实现此接口的类与排序方法结合,直接使用该类创建的实例来进行比较。而借助`Comparator`,可以灵活处理不同类型的数据或定制化的比较逻辑,例如在`Arrays.sort`或`Collections.sort`方法中传入`Comparator`对象。
在代码设计中,选择`Comparable`还是`Comparator`取决于比较规则的固定性和灵活性需要。若规则易变动,推荐使用`Comparator`,因为它提供独立的比较逻辑,简化了维护和扩展。如`String`和`Integer`等类自带的比较规则比较稳定且符合自然顺序,故往往选择实现`Comparable`。
深入源码分析,你将了解到接口的具体实现逻辑和行为,这对理解Java编程的核心逻辑至关重要。
java-增强版Comparator进行集合排序null异常处理
在Java开发中,我们有时会遇到使用增强版Comparator对集合进行排序时遇到null异常的问题。例如,当尝试对一个Student对象列表按照no、age、name和money进行排序时,如果列表中存在未赋值的no或money,就可能导致NullPointerException。为了解决这个问题,我们可以通过查阅Comparator的源码来找到解决策略。
Comparator类中的Objects.requireNonNull方法确保了比较对象和字段不能为空。针对null值,Comparator提供了两个有用的静态方法:nullsFirst和nullsLast。这两个方法分别将null视为小于或大于非null值,从而避免了排序时的null异常。例如,可以将代码修改为:
dataList.sort(Comparator.comparing(Student::getNo, Comparator.nullsFirst(String::compareTo).reversed()).thenComparing(Student::getAge)
.thenComparing(Student::getName).thenComparing(Student::getMoney));
在这个修改后的代码中,我们首先对no字段使用了nullsFirst,确保了null值的排序位置。Comparator.comparing方法允许我们指定比较函数,而Comparator.thenComparing则支持多字段排序。
除了这些,Comparator还提供了其他一些方法,如reversed、reverseOrder、naturalOrder等,用于调整排序顺序。比如,Comparator.reverseOrder()会反转排序顺序,Comparator.naturalOrder()则按照对象的自然顺序进行排序。这些方法可以根据实际需求灵活运用。
总的来说,通过使用Comparator的nullsFirst和nullsLast方法,我们可以有效地处理Java集合排序时的null异常问题,使得代码更加健壮。更多关于Comparator的方法可以参考Java 8的官方开发文档。
public static <T> int binarySearch(List<? extends T> list, T key, Comparator<? super T> c)
é®é¢1ï¼2å ¶å®å¯ä»¥ä¸èµ·è®²ï¼å°±æ¯ï¼ä½ 没å®å ¨ç解==ï¼equalsåèªå¨è£ ç®±ï¼auto boxing)ãä»ç»çä½ çcomparatorçå®ç°return i<j?-1:(i==j?0:1);è¿å¥è¯ï¼æ³¨æï¼ä½ çåæ°æ¯Integerç±»åï¼ä¸æ¯åºæ¬ç±»åintï¼ä½ 对类ç对象å==æä½ï¼æ¯æ¯è¾å®ä»¬æ¯å¦æ¯åä¸ä¸ªå¼ç¨ï¼èä¸æ¯ä»ä»¬çå¼æ¯å¦ç¸çãæ以ï¼ä½ ç¨è¿ä¸ªæ¯è¾å¨åäºåæç´¢ï¼ç»æè¯å®æ¯ä¸å¯é¢ç¥çãå½<å¤æ失败çæ¶åï¼åé¢ç==åºæ¬ä¸å¯è½æ¯trueï¼è¿ä¹æ¯ä¸ºä»ä¹if(integers.get(1)==new Integer(1)){ System.out.println("<3>");}è¿å¥è¯ä¸è½æå°åº<3>æ¥ãä½ åé¢é£ä¸ªå®ç°æ¯æ£ç¡®çï¼å 为类ç对象没æ<æä½å>æä½ï¼æ以ç¼è¯å¨ä¼æInteger对象èªå¨è½¬æintåæ§è¡æ¯è¾ã
é®é¢3ï¼apiåçå¾æ¸ æ¥ï¼å½æ¾ä¸å°çæ¶åï¼ä¼è¿åã-ï¼æå ¥å¼ï¼-1ãï¼å¨è¿ä¸ªç¨åºéï¼å ä¸ºä½ çæ¯è¾å¨åçä¸å¯¹ï¼æ以æ索失败ï¼å¹¶ä¸å®è®¤ä¸ºæå ¥å¼æ¯1ï¼è¿æ²¡æé®é¢åãå ¶å®ï¼å 为ä¸é¢è¯´çé®é¢ï¼ä»è¿åä»»ä½å¥å¥æªæªçæ°é½æå¯è½ã
å¦æä½ æ³å¯¹ä¸¤ä¸ªIntegerç±»ç对象æ¯è¾å¼ï¼ä½ å¯ä»¥è°ç¨i.eqauls(j);æè i.intValue()==j.intValue();intValueæ¹æ³è¿åçæ¯Integer对象å è£ çåºæ¬ç±»åçintå¼
å¦å¤ï¼è¡¥å ä¸ç¹ï¼ä¸ç¥éæ¯ä½ æè¿°çä¸å¥½ï¼è¿æ¯æç解çä¸å¯¹ãä½ è¯´çâæ ¹æ®APIæ档解éï¼ Comparatoråªæ¯å¨searchä¹å对listè¿è¡æåºãâä¸å¯¹ï¼binarysearchä¸ä¼æåºï¼èæ¯apiè¦æ±ä½ å¨è°ç¨binarySearchä¹åï¼å¿ é¡»ä¿è¯ä¼ è¿å»çlistæ¯å·²æåºäºçï¼ä½ å¯ä»¥è°ç¨Collections.sortæ¥å®ç°ï¼ä¹å¯ä»¥èªå·±åæåºç®æ³
=========================================================
comparatorçä½ç¨å°±æ¯æ¯è¾å¨åï¼åè¯æåºæ¹æ³ææ ·æ¯è¾ä¸¤ä¸ªå¼è°å¤§è°å°æç¸çï¼å¯¹äºIntegerï¼å½ç¶æ¯è¾è§åå¾ç´è§ï¼ä½æ¯å¯¹å«çç±»å¢ï¼æ¯å¦ä½ æä¸ä¸ªä¸ä¸ªStudentç±»ï¼ä½ å¸ææ ¹æ®å¦å·æ¥æåºï¼æ¥æ¾ï¼ä½ å°±éè¦å®ä¹èªå·±çComparatorï¼å½ç¶ä½ ä¹å¯ä»¥è®©ä½ çç±»å®ç°Comparableæ¥å£ï¼è¿æ ·ä½ å°±å¯ä»¥ç´æ¥è°ç¨binarySearchçå¦å¤ä¸ä¸ªä¸éè¦æ¯è¾å¨ççæ¬
=========================================================
æç¹ä¸æç½ï¼ä½ æ°è¡¥å çé®é¢æ¯é对æåªå¥è¯è®²çï¼ä½ è´´çAPIæ¯æ²¡éå¦ï¼ä½ç解ä¸å¯¹ãbinarySearchä¸ä¼æåºï¼æåºçæ¯sortï¼binarySearchå®ç°ä¸ä¸ä¼è°ç¨sortï¼è¿ç¹ä½ èªå·±çæºä»£ç å°±ç¥éäºï¼äºå®ä¸api表达çä¹æ¯è¿ä¸ªææï¼æ³¨æï¼åè¯æ¯âå¨è¿è¡æ¤è°ç¨ä¹åâï¼æææ¯ç¨æ·èªå·±è°ç¨sortåè°ç¨binarysearchï¼ãä½ ç¥épre-condition说æ³åï¼å表已æåºç¶æå°±æ¯binarySearchæ¹æ³æåçpre-conditionï¼åç½®æ¡ä»¶ï¼ï¼ä½ å¯ä»¥ä¼ ä¸ä¸ªä¹±åºçlistè¿å»ï¼æ²¡é®é¢ï¼ç¼è¯å¨ä¸ä¼æ¥éï¼ä½æ¯ä½ å¾ä¸å°èªå·±æ³è¦çç»æï¼è¿ä¸ªä½ èªå·±è¯å°±ç¥éäºã
=========================================================
æ±ããä½ çææé¾éä¸è¿æ¯searchä¼è°ç¨sortä¹ï¼å¦åï¼å¦æä½ æ¿è®¤searchä¸è°ç¨sortï¼é£ä¸ºä»ä¹è¿æçcomparatorä¼å¦åä¸æç´¢è¿ç¨ï¼å¦æsearchæ¢ä¸æåºï¼åä¸ä½¿ç¨comparatorï¼é£è¿ä¸ªåæ°ä¸å°±æ²¡æç¨äºåï¼
æ以ï¼searchéè¦comparatorï¼åªç¨æ¥æç´¢ï¼åæåºæ¯«æ å ³ç³»ãï¼ä½ åºè¯¥ç¥éäºåæç´¢æ¯æä¹æ§è¡çå§ï¼é£å°±å¾æ¸ æ¥ä¸ºä»ä¹éè¦ä¸ä¸ªcomparatoräºï¼