Java中CompareTo()方法的问题
@OverridepublicintcompareTo(Objectobj){UserModelum=(UserModel)obj;if(this.getUserId()...
@Override
public int compareTo(Object obj) {
UserModel um = (UserModel)obj;
if(this.getUserId().compareTo(um.getUserId())>0){
return 1;
}else if(this.getUserId().compareTo(um.getUserId())==0){
return 0;
}else{
return -1;
}
}
用在集合TreeSet的排序,我在自定义的UserModel类中重写了这个方法,为什么我没有手动传入obj,它却可以实现排序的功能?请问这是什么原理,重点是if后面的那个判断我不能理解 展开
public int compareTo(Object obj) {
UserModel um = (UserModel)obj;
if(this.getUserId().compareTo(um.getUserId())>0){
return 1;
}else if(this.getUserId().compareTo(um.getUserId())==0){
return 0;
}else{
return -1;
}
}
用在集合TreeSet的排序,我在自定义的UserModel类中重写了这个方法,为什么我没有手动传入obj,它却可以实现排序的功能?请问这是什么原理,重点是if后面的那个判断我不能理解 展开
4个回答
展开全部
楼上正解,应为um.getUserId()内容已经实现compareTo 接口功能
Java.lang.String API中有定义
compareTo
public int compareTo(String anotherString)按字典顺序比较两个字符串。该比较基于字符串中各个字符的 Unicode 值。将此 String 对象表示的字符序列与参数字符串所表示的字符序列进行比较。如果按字典顺序此 String 对象在参数字符串之前,则比较结果为一个负整数。如果按字典顺序此 String 对象位于参数字符串之后,则比较结果为一个正整数。如果这两个字符串相等,则结果为 0;compareTo 只有在方法 equals(Object) 返回 true 时才返回 0。
Java.lang.String API中有定义
compareTo
public int compareTo(String anotherString)按字典顺序比较两个字符串。该比较基于字符串中各个字符的 Unicode 值。将此 String 对象表示的字符序列与参数字符串所表示的字符序列进行比较。如果按字典顺序此 String 对象在参数字符串之前,则比较结果为一个负整数。如果按字典顺序此 String 对象位于参数字符串之后,则比较结果为一个正整数。如果这两个字符串相等,则结果为 0;compareTo 只有在方法 equals(Object) 返回 true 时才返回 0。
展开全部
compareTo方法中,如果前面的值大返回1,如果后面的大于,前面的,返回-1,或者等于前面的,返回0,举例:
int cc= "13".compareTo("12");
System.out.println(cc);
int dd= "11".compareTo("12");
System.out.println(cc);
int dd= "aaa".compareTo("aaa");
System.out.println(cc);
结果就是:1(换行) -1(换行)0。
备注:除了compareTo方法外,为了比较字母,还有compareToIgnoreCase(忽略大小写比较),用法和compareTo方法相同。
int cc= "13".compareTo("12");
System.out.println(cc);
int dd= "11".compareTo("12");
System.out.println(cc);
int dd= "aaa".compareTo("aaa");
System.out.println(cc);
结果就是:1(换行) -1(换行)0。
备注:除了compareTo方法外,为了比较字母,还有compareToIgnoreCase(忽略大小写比较),用法和compareTo方法相同。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你的getUserId()方法返回的是一个字符串吧?或者是Integer等类 这些类的源代码里已经实现了Comparable接口 所以可以直接进行this.getUserId().compareTo(um.getUserId())比较
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
TreeSet 采用的是红黑树技术,一种二叉排序树(BST)
必须指定 compareTo方法或者是传入 Comparator
对象就按指定的关系进行储存,二叉排序树是有序的容器。
必须指定 compareTo方法或者是传入 Comparator
对象就按指定的关系进行储存,二叉排序树是有序的容器。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询