Java TreeMap是一种基于红黑树实现的有序映射,它默认使用键的自然顺序进行排序。如果需要使用自定义比较器进行排序,可以在创建TreeMap对象时传入一个实现了Comparator接口的比较器对象。 然而,在使用自定义比较器时,有时会出现奇怪的行为。例如,当比较器返回0时,TreeMap会认为两个键是相等的,但是在插入时却会将它们视为不同的键,导致插入失败。 这种行为的原因是,TreeMap在比较键的顺序时,不仅仅依赖于比较器的返回值,还依赖于键的hashCode和equals方法。如果两个键的hashCode不同,即使比较器返回0,它们也会被视为不同的键。因此,在自定义比较器时,需要确保hashCode和equals方法的实现与比较器的逻辑一致,否则会导致奇怪的行为。 另外,如果自定义比较器的逻辑不满足传递性,也会导致TreeMap的排序出现问题。因此,在实现自定义比较器时,需要注意比较器的逻辑是否满足传递性。