Java复习-set集合
2017-01-31 11:14
211 查看
set集合其实就是一个collection集合,只是set集合有一点点不一样的地方就是set集合不允许包含重复的集合,如果试图将两个相同的元素放入set集合,则会发生失败,并且不会加入进去。
hashset是set的典型实现,大多数时候使用set的时候就是使用这个类进行实现,hashset是按hash算法来存储集合中的元素,因此具有很好的存取和查找性能。
hash算法的价值在于速度
LinkedHashSet 性能略低于hashset 但是在迭代查找的时候性能很好,同样不能插入相同的数据,如果插入了相同数据,则会回馈出来的false,不会抛出异常。
LinkedHashSet books=new LinkedHashSet();
books.add("Thinking in java");
books.add("php编程基础");
books.add("python 网络编程");
System.out.println(books);
books.remove("Thinking in java");
System.out.println(books);
TreeSet如果能正常运行的话,treeset必须接受的是同一种类型的对象,两个对象如果相等的话则没办法无法插入。判断两个对象是否相等的话,主要看compareTo(object obj)方法比较是否是返回为0
性能的比较:
HashSet和treeset是set的两个典型案列,hashset的性能总是比Treeset的性能好,特别是常用于查询,插入,等操作,因为treeset需要维护红黑树算法,只有当需要维护一个保持排序的set时,才用treeset。
hashset是set的典型实现,大多数时候使用set的时候就是使用这个类进行实现,hashset是按hash算法来存储集合中的元素,因此具有很好的存取和查找性能。
hash算法的价值在于速度
LinkedHashSet 性能略低于hashset 但是在迭代查找的时候性能很好,同样不能插入相同的数据,如果插入了相同数据,则会回馈出来的false,不会抛出异常。
LinkedHashSet books=new LinkedHashSet();
books.add("Thinking in java");
books.add("php编程基础");
books.add("python 网络编程");
System.out.println(books);
books.remove("Thinking in java");
System.out.println(books);
TreeSet如果能正常运行的话,treeset必须接受的是同一种类型的对象,两个对象如果相等的话则没办法无法插入。判断两个对象是否相等的话,主要看compareTo(object obj)方法比较是否是返回为0
性能的比较:
HashSet和treeset是set的两个典型案列,hashset的性能总是比Treeset的性能好,特别是常用于查询,插入,等操作,因为treeset需要维护红黑树算法,只有当需要维护一个保持排序的set时,才用treeset。
相关文章推荐
- Ubuntu下搭建JavaEE开发环境
- 笔记-struts2
- Java相关文章索引(4)
- java8 并行编程教程——Threads 和 Executors
- java基本类型的默认值
- java中的File对象
- 蓝桥杯 - 算法训练 - 删除数组零元素 - Java
- java 中的wait & notify
- Springmvc中配置Quartz
- Spring官网改版后下载地址
- Eclipse报错:java.lang.ClassNotFoundException: ContextLoaderListener
- spring 启动报ClassMetadataReadingVisitor 错误
- Struts2类型转换实例
- java企业网站源码,模版,有前后台,springmvcSSM,生成静态化
- 蓝桥杯 冒泡排序
- java定时器实现总结
- Spring注解
- Spring在多线程下@Resource注入为null
- 获取Java方法签名
- JavaEE-Servlet-Filter和Listener