楼上正解,应为um.getUserId()内容已经实现compareTo 接口功能
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方法相同。
你的getUserId()方法返回的是一个字符串吧?或者是Integer等类 这些类的源代码里已经实现了Comparable接口 所以可以直接进行this.getUserId().compareTo(um.getUserId())比较
TreeSet 采用的是红黑树技术,一种二叉排序树(BST)
必须指定 compareTo方法或者是传入 Comparator
对象就按指定的关系进行储存,二叉排序树是有序的容器。