Set HashSet

public static void main(String[] args) {

//不可以重复  并且是无序的
  //自然排序  从A-Z
  //eqauls从Object继承,默认比较地址
//  Set<String> set= new HashSet<>();
//  set.add("zs");
//  set.add("ls");
//  set.add("ww");
//  set.add("qq");
//  set.add("zs");
//  System.out.println(set.size());
//  //遍历
  //迭代器
//  Iterator<String > it= set.iterator();
//  while(it.hasNext()) {
//   System.out.println(it.next());
//  }
//  System.out.println("-------------------");
//  //Foreach
//  for(String s: set) {
//   System.out.println(s);
//  }
  
  //常用实现类  HashSet
  Set<Person> s= new HashSet<>();
   //System.out.println(new Person(1,"ls",18).equals(new Person(1,"zs",18)));
   //System.out.println(new Person(1,"zs",18));
  s.add(new Person(1,"zs",18));
  s.add(new Person(2,"ls",18));
  s.add(new Person(3,"ww",18));
  s.add(new Person(4,"zl",18));
  s.add(new Person(5,"qq",18));
  
  //foreach的底层原理就是迭代器
  for(Person p:s) {
   //默认转换为String的数据类型
   System.out.println(p);
  }
  
 }

TreeSet

public static void main(String[] args) {

//常用实现类  TreeSet :根据某种(规则)对里面的元素进行排序
                 //规则1 :java.lang.Comparable
                 //规则2 :java.util.Comparator
//  Set<String> set= new TreeSet<>();
//  set.add("zs");
//  set.add("ls");
//  set.add("ww");
//  set.add("qq");
//  set.add("zs");
//  System.out.println(set.size());
//

遍历

迭代器
//  Iterator<String > it= set.iterator();
//  while(it.hasNext()) {
//   System.out.println(it.next());
//  }
//  System.out.println("-------------------");
//  Foreach
//  for(String s: set) {
//   System.out.println(s);
//  }
  
  //自然排序器
  
//  Set<Person> s= new TreeSet<>();
//   //System.out.println(new Person(1,"ls",18).equals(new Person(1,"zs",18)));
//   //System.out.println(new Person(1,"zs",18));
//  s.add(new Person(1,"zs",18));
//  s.add(new Person(2,"ls",18));
//  s.add(new Person(3,"ww",18));
//  s.add(new Person(4,"zl",18));
//  s.add(new Person(5,"qq",18));
//  
//  //foreach的底层原理就是迭代器
//  for(Person p:s) {
//   //默认转换为String的数据类型
//   System.out.println(p);
//  }
  
  // 自定义的排序器(根据年龄排序)
  Set<Person> s= new TreeSet<>(new Age());
   //System.out.println(new Person(1,"ls",18).equals(new Person(1,"zs",18)));
   //System.out.println(new Person(1,"zs",18));
  s.add(new Person(1,"zs",18));
  s.add(new Person(2,"ls",19));
  s.add(new Person(3,"ww",80));
  s.add(new Person(4,"zl",30));
  s.add(new Person(5,"qq",20));

for(Person p:s) {
   System.out.println(p);
  }
  
 }

Set的常用实现类HashSet和TreeSet的更多相关文章

  1. Java 基础 - Set接口 及其实现类HashSet/LinkedHashSet/TreeSet

    笔记: /**Set接口 及其实现类 * 公用操作同Collection: * * ①size(),clear()②isEmpty(),③contains(),④add()方法 和remove()方法 ...

  2. Java开发笔记(六十五)集合:HashSet和TreeSet

    对于相同类型的一组数据,虽然Java已经提供了数组加以表达,但是数组的结构实在太简单了,第一它无法直接添加新元素,第二它只能按照线性排列,故而数组用于基本的操作倒还凑合,若要用于复杂的处理就无法胜任了 ...

  3. HashSet,TreeSet和LinkedHashSet的区别

    1. Set接口 Set不允许包含相同的元素,如果试图把两个相同元素加入同一个集合中,add方法返回false. Set判断两个对象相同不是使用==运算符,而是根据equals方法.也就是说,只要两个 ...

  4. 算法竞赛中的常用JAVA API :HashSet 和 TreeSet(转载)

    算法竞赛中的常用JAVA API :HashSet 和 TreeSet set set容器的特点是不包含重复元素,也就是说自动去重. HashSet HashSet基于哈希表实现,无序. add(E ...

  5. Java集合框架之四大接口、常用实现类

    Java集合框架 <Java集合框架的四大接口> Collection:存储无序的.不唯一的数据:其下有List和Set两大接口. List:存储有序的.不唯一的数据: Set:存储无序的 ...

  6. 30、Java中Set集合之HashSet、TreeSet和EnumSet

    Set集合是Collection的子集,Set集合与Collection基本相同,没有提供任何额外的方法,只是Set不允许包含重复的元素. Set集合3个实现类:HashSet.TreeSet.Enu ...

  7. Map接口常用实现类学习

    HashMap 1.6的HashMap:数组加单向链表结构 最重要的内部类Entry,全类名是java.util.HashMap.Entry,是个静态类,实现了Map.Entry接口.HashMap. ...

  8. Java集合详解7:一文搞清楚HashSet,TreeSet与LinkedHashSet的异同

    <Java集合详解系列>是我在完成夯实Java基础篇的系列博客后准备开始写的新系列. 这些文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查 ...

  9. List接口和Set接口及其常用实现类概述

    一.List接口 List:有序的 collection(也称为序列).此接口的用户可以对列表中每个元素的插入位置进行精确地控制.用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元 ...

随机推荐

  1. Python 运算符 各类运算符总结

    运算符详解2.1.算术运算符2.2.比较(关系)运算符2.3.赋值运算符2.4.逻辑运算符2.5.位运算符2.6.成员运算符2.7.身份运算符三.重要运算符说明3.1.join和符号”+“区别3.2. ...

  2. R学习笔记3 数据处理

    1,日期类型 日期类型比较特殊,日期值通常以字符串的形式输入到R中,然后使用as.Date()函数转换为以数值形式存储的日期变量 mydate <- as.Date("2019-01- ...

  3. AS3灰色图像

    一开始觉得AS3的滤镜很难使用,尤其是那些矩阵,让人望而生畏.最近写一个聊天模块,要用到离线状态下的灰色头像,于是认真研究了ColorMatrixFilter,发现其实也没有那么难.所谓的矩阵其实就是 ...

  4. docker相关--开始使用swarm模式

    Swarm简介 Swarm是Docker的一个编排工具,参考官网:https://docs.docker.com/engine/swarm/ Swarm 模式简介 要在Swarm模式下运行docker ...

  5. vue 项目中assets 和static的区别

    一.Webpacked Assets 为了回答这个问题,我们首先需要了解Webpack如何处理静态资产.在 *.vue 组件中,所有模板和CSS都会被 vue-html-loader 及 css-lo ...

  6. JML规格编程系列——OO Unit3分析和总结

    本文是BUAA OO课程Unit3在课程讲授.三次作业完成.自测和互测时发现的问题,以及倾听别人的思路分享所引起个人的一些思考的总结性博客.主要包含JML相关梳理.SMT Solver验证.JML单元 ...

  7. ubuntu18.04使用vscode报pylint is not install错误

    1.安装pip:sudo apt-get install pip,如果使用python3则需要安装pip3:sudo apt-get install python3-pip 2.使用pip安装pyli ...

  8. 【转载】C#中可使用string.Empty代表空字符

    在C#中,如果赋值一个字符串为空白字符串,我们一般会用“”的形式对字符串进行赋值操作,其实在C#的字符串类String类中,有个专门的常量string.Empty来代表空字符串,可直接在赋值的时候使用 ...

  9. python day10: 反射补充,面向对象

    目录 pythdon day 10 1. 反射补充 16. 面向对象 16.1 面向对象初步介绍 16.2 面向对象和面向过程区别 16.3 对象的进化 17. 类class 17.1 类的定义 17 ...

  10. Postgres 多实例实例部署方式

    Postgres 数据库在原有示例正常运行情况下,新增一个端口示例,主要目的解决新的项目和原有项目的数据库部署不在冲突,可以独立运行,备份和还原数据互不影响,主要用的的命令有  initdb 数据库初 ...