String类下compareTo()与compare()方法比较
String类下compareTo()与compare()方法比较
这两个方法经常搞混淆,现对其进行总结以加深记忆。
compareTo(Objecto)方法是java.lang.Comparable接口中的方法, 当需要对某个类的对象进行排序时,该类需要实现Comparable 接口的, 必须重写publicintcompareTo(To)方法, 比如MapReduce中Map函数和Reduce函数处理的 , 其中需要根据key对键值对进行排序,所以,key实现了WritableComparable 接口, 实现这个接口可同时用于序列化和反序列化。 WritableComparable 接口(用于序列化和反序列化)是Writable接口和Comparable 接口的组合; 判断字符串大小的依据是根据它们在字典中的顺序决定的。 如果参数字符串等于此字符串,则返回0值; 如果按字典顺序此字符串小于字符串参数,则返回一个小于0的值; 如果按字典顺序此字符串大于字符串参数,则返回一个大于0的值。 compare(Objecto1,Objecto2)方法是java.util.Comparator 接口的方法, 它实际上用的是待比较对象的compareTo(Objecto)方法。
下面我们写一来看看上面两个方法是怎么用的:
首先,写一个User类,代码如下:
publicclassUserimplementsComparable
接下来,我们写一个测试类Test:
publicclassTest{ //编写Comparator,根据User的id对User进行排序 privatestaticfinalComparatorCOMPARATOR=newComparator (){ publicintcompare(Usero1,Usero2){ returno1.compareTo(o2); //运用User类的compareTo方法比较两个对象 } }; publicstaticvoidmain(String[]args){ ArrayList student=newArrayList (); Useruser1=newUser(1,"yueliming"); Useruser2=newUser(2,"yueliming"); Collections.sort(student,COMPARATOR);//用我们写好的Comparator对student进行排序 for(inti=0;i 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!