java中Comparator接口,为什么o1.length()-o2.length()就是升序,o2.length() - o1.lengh()就是降序呢?
packagetest;importjava.util.Arrays;importjava.util.Comparator;publicclassDemo01{publi...
package test;
import java.util.Arrays;
import java.util.Comparator;
public class Demo01 {
public static void main(String[] args) {
String[] strArr = {"aaa","b","cc"};
Arrays.sort(strArr, new Comparator<String>(){
public int compare(String o1, String o2) {
return o1.length() - o2.length();
}
});
System.out.println(Arrays.toString(strArr));//[b, cc, aaa]
}
}
java中comparator接口,为什么o1.length() - o2.length() 就是升序,o2.length() - o1.lengh()就是降序呢?求大神解释一下 展开
import java.util.Arrays;
import java.util.Comparator;
public class Demo01 {
public static void main(String[] args) {
String[] strArr = {"aaa","b","cc"};
Arrays.sort(strArr, new Comparator<String>(){
public int compare(String o1, String o2) {
return o1.length() - o2.length();
}
});
System.out.println(Arrays.toString(strArr));//[b, cc, aaa]
}
}
java中comparator接口,为什么o1.length() - o2.length() 就是升序,o2.length() - o1.lengh()就是降序呢?求大神解释一下 展开
3个回答
展开全部
并不是因为o1.length() - o2.length() 就是升序,o2.length() - o1.lengh()就是降序,而是因为
你实现了用Comparator这个接口的时候,就有compare这个方法,JDK会在比较的时候自动调用这个方法,当该方法返回正数时,以第一个参数大于第二个,反之亦然。
这里只是用了2个String参数的长度来决定哪个比较大,你也可以自己来实现比较的逻辑。比如传入的2个参数的第一个字母比较之类的。javase的问题多看书。看帖子和问人得来的收获太小了。
建议啃完《thinking in java》
你实现了用Comparator这个接口的时候,就有compare这个方法,JDK会在比较的时候自动调用这个方法,当该方法返回正数时,以第一个参数大于第二个,反之亦然。
这里只是用了2个String参数的长度来决定哪个比较大,你也可以自己来实现比较的逻辑。比如传入的2个参数的第一个字母比较之类的。javase的问题多看书。看帖子和问人得来的收获太小了。
建议啃完《thinking in java》
展开全部
按 compare 方法的定义
负数 o1 < o2
0 o1 = o2
正数 o1 > o2
o1.length() - o2.length() 的结果与定义一致
o2.length() - o1.lengh()的结果与定义正好相反,是逆序
负数 o1 < o2
0 o1 = o2
正数 o1 > o2
o1.length() - o2.length() 的结果与定义一致
o2.length() - o1.lengh()的结果与定义正好相反,是逆序
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
同样好奇中
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询