zuul如果两个filter的order一样,是如何排序的?(下)

简介: zuul如果两个filter的order一样,是如何排序的?(下)

正文


如果filterOrder一样如何排序?


我们看看Integercompare方法具体的逻辑

4.png

如果x==y,则返回0,x

5.png

看到这里,我们得出这样的结论,如果filterOrder一样,则Collections.sort(list);排序时不交换位置,这按照ZuulFilter默认加载顺序。那么,ZuulFilter的默认加载顺序是怎么样的?

7.png

它是通过getAllFilters方法获取ZuulFilter集合,该方法其实返回的是名称为filtersConcurrentHashMapvalues,即返回Set集合,是无序的。


  • 重要的事情说三遍:如果filterOrder一样,ZuulFilter是无序的。
  • 重要的事情说三遍:如果filterOrder一样,ZuulFilter是无序的。
  • 重要的事情说三遍:如果filterOrder一样,ZuulFilter是无序的。

所以,filterOrder切记不要定义相同的,不然可能会出现无法预知的执行结果。


两种排序方法


自定义排序其实有两种方法:

  • 实现Comparable接口,重写compareTo方法,
  • 实现Comparator接口,重写compare方法如果要使用Collections.sort(list);排序,它默认用的是第一种方法,上面的filterOrder之所以可以排序,是因为Integer实现了Comparable接口,重写了compareTo方法


6.png


如果想自己定义排序规则可以通过实现Comparator接口,重写compare方法。


Collections.sort(list,new Comparator<Integer>(){
    @Override
    public int compare(Integer o1, Integer o2) {
        return o2 - o1;
    }
});


它的底层也是通过二分查找实现的

8.png


那么这两种方法有什么区别呢?


  • Comparable接口位于java.lang包下,而Comparator接口位于java.util包下。
  • Comparable接口是内部比较器,一个类如果想要使用Collections.sort(list) 方法进行排序,则需要实现该接口
  • Comparator接口是外部比较器用于对那些没有实现Comparable接口或者对已经实现的Comparable中的排序规则不满意进行排序.无需改变类的结构,更加灵活。


彩蛋


zuul中是通过filterOrder参数的大小排序的,而在spring中是通过@Order注解排序的。

3.png

默认情况下,如果不指定value值,则value是Integer的最大值。

由于排序规则是value越小,则排在越靠前,所以如果不指定value值,则它排在最后。

2.png

spring是通过OrderComparator类排序的,它实现了Comparator接口,它的doCompare方法实现的排序。

1.png

最终也是调用Integer类的compare方法,该方法前面已经介绍过了。

相关文章
Stream方法使用-filter、sorted、distinct、limit
Stream方法使用-filter、sorted、distinct、limit
126 0
WK
|
3月前
|
存储 Python
filter函数
在Python中,filter() 函数是另一个内置的高阶函数,它用于过滤序列,过滤掉那些不符合条件的元素,返回由符合条件元素组成的新迭代器。filter() 函数接收两个参数:一个函数和一个可迭代对象。这个函数用于测试可迭代对象中的每个元素,如果元素满足条件(即函数返回True),则保留该元素;否则,该元素被过滤掉。
WK
63 0
|
5月前
|
Python
filter
【7月更文挑战第10天】
46 2
|
7月前
|
JavaScript 前端开发
filter() 方法使用
filter() 方法使用
50 0
filter的使用
常见的场景:当我们从后端请求到数据列表时,我们需要对其中符合条件的数据进行筛选、当我们拿到数据,我们希望把英文首字母大写,数组去重等等。
es6 filter方法的使用
es6 filter方法的使用
108 0
|
搜索推荐 算法
|
搜索推荐 算法
|
Web App开发 前端开发