0.前言

ThreeSet的底层实现是红黑树,它在创建set的过程中实现排序。Collections.sort是在对整个集合进行排序,按道理来说使用TreeSet插入集合元素直至建立整个TreeSet过程中实现排序在时间方面要比Collections.sort对整个集合进行排序效率要高很多,因为它在每次搜索要插入的位置时耗费的时间为log(n),n代表的是当前集合的长度,但实验表明使用Collections.sort对集合进行排序时间耗费要少些。

返回类型为int型

        Collections.sort(appIds, new Comparator<AfaApplication>() {
@Override
public int compare(AfaApplication app1, AfaApplication app2) {
if(StringUtils.isNotNullAndBlank(app1.getAppId())&&StringUtils.isNotNullAndBlank(app2.getAppId())){
return Integer.parseInt(app1.getAppId())-Integer.parseInt(app2.getAppId());
}else{
return ;
}
}
});

有时候会报错

java.lang.NumberFormatException: For input string: "006006003002"

有几种可能,有可能字段转换值超了,有可能获取的字段为空或者为null无法转为数据,这时候就要判断为空或者null

值超了和null的情况处理:

        Collections.sort(appMenuTreeList, new Comparator<AppMenuTree>() {
@Override
public int compare(AppMenuTree tree1, AppMenuTree tree2) {
if(StringUtils.isNotNullAndBlank(tree1.getTreeId())&&StringUtils.isNotNullAndBlank(tree2.getTreeId())){
return Long.parseLong(tree1.getTreeId())>Long.parseLong(tree2.getTreeId())?:-;
}else{
return ;
}
}
});

有时候会报错

Comparison method violates its general contract
      Collections.sort(appMenuTreeList, new Comparator<AppMenuTree>() {
@Override
public int compare(AppMenuTree tree1, AppMenuTree tree2) {
if(StringUtils.isNotNullAndBlank(tree1.getTreeId())&&StringUtils.isNotNullAndBlank(tree2.getTreeId())){
             if(Long.parseLong(tree1.getTreeId())==Long.parseLong(tree2.getTreeId())){
               return ;
             }else{
return Long.parseLong(tree1.getTreeId())>Long.parseLong(tree2.getTreeId())?:-;
              }
}else{
return ;
}
}
});
        Collections.sort(roleList, new Comparator<AfaRole>() {
@Override
public int compare(AfaRole tree1, AfaRole tree2) {
if(StringUtils.isNotNullAndBlank(tree1.getRoleCode())&&StringUtils.isNotNullAndBlank(tree1.getRoleCode())){
return tree1.getRoleCode().compareToIgnoreCase(tree2.getRoleCode());
}else{
return ;
}
}
});

1.性能比较

 
数据规模 循环次数 Collections.sort耗时(微妙) TreeSet耗时(微妙)
1000000 10 339332微秒 1215165微秒
100000 10 24547微秒 49862微秒
10000 10 3246微秒 3884微秒
1000 10 752微秒 1097微秒

测试机器:windows、2.2GHz、Core i5、8G

2.测试代码

package com.google.common.base;

import com.google.common.collect.Lists;
import com.google.common.primitives.Ints;
import org.junit.Test; import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.TreeSet; public class SortTest {
public static final int DEFAULT_ARRAY_LENGTH = * * ; private List<Integer> createList(int arrLength) {
List<Integer> numbers = Lists.newArrayList();
for(int i = ; i < DEFAULT_ARRAY_LENGTH; i++) {
numbers.add(i);
}
Collections.shuffle(numbers);
return numbers;
}
public long testCollectionsSort(List<Integer> numbers) {
Ticker ticker = Ticker.systemTicker();
long startTime = ticker.read();
Collections.sort(numbers, new Comparator<Integer>() {
public int compare(Integer o1, Integer o2) {
return Ints.compare(o2, o1);
}
});
//long endTime = ticker.read();
//System.out.println("[testCollectionsSort]" + (endTime - startTime) / 1000);
//System.out.println("[testCollectionsSort]" + numbers.toString());
return (ticker.read() - startTime) / ;
} public long testSortedMap(List<Integer> numbers) {
Ticker ticker = Ticker.systemTicker();
long startTime = ticker.read();
TreeSet<Integer> sortedNumberSet = new TreeSet<Integer>(new Comparator<Integer>() {
public int compare(Integer o1, Integer o2) {
return Ints.compare(o2, o1);
}
});
sortedNumberSet.addAll(numbers);
//long endTime = ticker.read();
//System.out.println("[testSortedMap]" + (endTime - startTime) / 1000);
//List<Integer> newNumbers = Lists.newArrayList(sortedNumberSet);
//System.out.println("[testSortedMap]" + newNumbers.toString());
return (ticker.read() - startTime) / ;
} @Test
public void testSortMethodCompare() {
int loopCount = ;
long collectionsSortTimeTotalCount = ;
long sortedMapTimeTotalCount = ;
List<Integer> numbers = createList(DEFAULT_ARRAY_LENGTH);
for(int i = ; i < loopCount; i ++) {
List<Integer> tempNumbers = Lists.newArrayList(numbers);//每次循环使用同样数据
sortedMapTimeTotalCount += testSortedMap(tempNumbers);//不会改变tempNumbers
collectionsSortTimeTotalCount += testCollectionsSort(tempNumbers);
}
long collectionsSortTimeCount = collectionsSortTimeTotalCount / loopCount;
long sortedMapTimeCount = sortedMapTimeTotalCount / loopCount;
System.out.println("[testSortMethodCompare] loopCount = " + loopCount
+ ",listSize = " + DEFAULT_ARRAY_LENGTH);
System.out.println("[CollectinSort]" + collectionsSortTimeCount + "微秒");
System.out.println("[SortedMapSort]" + sortedMapTimeCount + "微秒");
}
}

3.性能差异分析

a.TreeSet每次搜索要插入的位置时耗费的时间为log(n),n代表的是当前集合的长度,n从1增加至排序的数据集合list的list.size(),这个相比Collections.sort直接对整个数据集合进行排序具有优势。

b.TreeSet一个明显的劣势排序的过程是插入新节点的过程,创建新节点,插入新节点应该也会耗费一定的时间。

c.TreeSet另一个明显的劣势为由于其底层实现为红黑树,所以每次插入后需要对原有的集合进行修改以使得新集合底层仍然是红黑树。

以上是TreeSet实现排序的优势和劣势,由性能比较数据可以看出,相比TreeSet实现排序的优势,其劣势更明显。

Collections排序的更多相关文章

  1. 集合框架工具类--Collections排序

    package ToolCollectionsDemo; import java.util.ArrayList; import java.util.Collections; import java.u ...

  2. Collections -集合排序compareTo方法重写,shuffle,addall

    package cn.learn.collection.Collections; /* 排序的对象的类,实现comparable借口,重写compareto方法 若要打印必须重写toString方法, ...

  3. java 集合Collections 工具类:排序,查找替换。Set、List、Map 的of方法创建不可变集合

    Collections 工具类 Java 提供1个操作 Set List Map 等集合的工具类 Collections ,该工具类里提供了大量方法对集合元素进行排序.查询和修改等操作,还提供了将集合 ...

  4. Java基础之常用类

    1.Collections类: (1)此类完全由在 collection 上进行操作或返回 collection 的静态方法组成. (2)静态方法摘要: static <T> boolea ...

  5. Java 集合补充

    集合大致可以分List,Set,Queue,Map四种体系. 集合和数组不一样,数组元素可以是基本类型的值,也可以是对象(的引用变量),集合里只能保存对象(的引用变量). 访问:如果访问List集合中 ...

  6. JAVA学习基础知识总结(原创)

    (未经博主允许,禁止转载!) 一.基础知识:1.JVM.JRE和JDK的区别: JVM(Java Virtual Machine):java虚拟机,用于保证java的跨平台的特性. java语言是跨平 ...

  7. Java 基础总结大全

    Java 基础总结大全 一.基础知识 1.JVM.JRE和JDK的区别 JVM(Java Virtual Machine):java虚拟机,用于保证java的跨平台的特性. java语言是跨平台,jv ...

  8. Java基础总结大全

    一.基础知识: 1.JVM.JRE和JDK的区别: JVM(Java Virtual Machine):java虚拟机,用于保证java的跨平台的特性. java语言是跨平台,jvm不是跨平台的. J ...

  9. java基础-容器

    已经写了一段时间JAVA代码了,但仔细想来,却发现对JAVA的很多方面还是一片迷茫. 利用周末补一下基础知识吧. 大致列一下这个周末需要学习的内容 1 容器 (本节内容) 2 线程 3 流 目录 1 ...

随机推荐

  1. Scala:scala的一些简单操作命令

    Scala是一门多范式的编程语言,一种类似java的编程语言,设计初衷是实现可伸缩的语言.并集成面向对象编程和函数式编程的各种特性. 不太久之前编程语言还可以毫无疑意地归类成“命令式”或者“函数式”或 ...

  2. 非法字符: '\ufeff' 解决方案|错误: 需要class, interface或enum

    解决方案,把文件用Editplus打开,UTF-8+BOM编码的文件转为普通的UTF-8文件

  3. OpenVpn部署使用easy-rsa-3.0

    OpenVpn简介 OpenVPN是一个用于创建虚拟专用网络(Virtual Private Network加密通道的免费开源软件.使用OpenVPN可以方便地在家庭.办公场所.住宿酒店等不同网络访问 ...

  4. springboot学习(三)——使用HttpMessageConverter进行http序列化和反序列化

    以下内容,如有问题,烦请指出,谢谢! 对象的序列化/反序列化大家应该都比较熟悉:序列化就是将object转化为可以传输的二进制,反序列化就是将二进制转化为程序内部的对象.序列化/反序列化主要体现在程序 ...

  5. HDU 5703

    题意:给你一个数n,问将n分为正整数和的方案数.如n=3共四种,1 1 1 , 1 2 , 2 1 ,3 . 思路:隔板法,n个1,有n-1个空位,每个空位可以选择是否插入隔板,插入k(0<=k ...

  6. 用WAR的方式部署SpringBoot项目

    接SpringBoot 快速入门(Eclipse) 步骤一:部署方式 Springboot 和 web 应用程序不一样,其本质上是一个 Java 应用程序,那么又如何部署呢? 通常来说,Springb ...

  7. redis主从、集群、哨兵

    redis的主从.集群.哨兵 参考: https://blog.csdn.net/robertohuang/article/details/70741575 https://blog.csdn.net ...

  8. Autofac Getting Started(默认的构造函数注入)

    https://autofaccn.readthedocs.io/en/latest/getting-started/index.html The basic pattern for integrat ...

  9. spring cloud 基本小结

    Spring cloud系列十四 分布式链路监控Spring Cloud Sleuth https://blog.csdn.net/hry2015/article/details/78905489 S ...

  10. Python基础笔记系列五:元组

    本系列教程供个人学习笔记使用,如果您要浏览可能需要其它编程语言基础(如C语言),why?因为我写得烂啊,只有我自己看得懂!! 元组 1)元组的结构和访问.使用方法和列表基本一致,区别主要有两点:1.使 ...