SortedSet03

  • 让SortedSet集合完成比较,还有另外一种方法,那就是单独编写一个比较器。 java.util.comparator

  • 在TreeSet集合创建的时候可以在集合中传入一个比较器,以后添加元素的时候会先金国比较器的比较再添加进去。

    SortedSet sortedSet= new TreeSet(new ProduceComparatora());

  • 也可以通过匿名内部类的方式来写比较器

 SortedSet sortedSet= new TreeSet(new Comparator(){

           比较器实现

    }); 但是匿名内部类的方式来写的话,这个比较器就只能再此程序中用了。

  • 代码

       package com.shige.Collection.Set.SortedSet;
    
       import java.util.Comparator;
    import java.util.Iterator;
    import java.util.SortedSet;
    import java.util.TreeSet; public class SortedSet03 {
    public static void main(String[] args) { //创建集合 在TreeSet集合创建的时候可以在集合中传入一个比较器,以后添加元素的时候会先金国比较器的比较再添加进去。
    SortedSet sortedSet= new TreeSet(new ProduceComparatora()); //创建元素对象
    Produce produce1=new Produce("拯救者R700P",10001,8999);
    Produce produce2=new Produce("机械革命",20002,7699);
    Produce produce3=new Produce("ROG",30003,8499); //添加元素
    sortedSet.add(produce1);
    sortedSet.add(produce2);
    sortedSet.add(produce3); // 遍历集合 Iterator iterator=sortedSet.iterator();
    while(iterator.hasNext()){
    Object produce=iterator.next();
    System.out.println(produce);
    } }
    } class Produce {
    String name;
    int no;
    double price; //构造方法
    Produce(){}
    Produce(String name,int no,double price){
    this.name=name;
    this.no=no;
    this.price=price;
    } // 重写toString方法
    public String toString(){
    return "Produce[商品名: "+name+" 商品编号: "+no+" 商品价格: "+price+"]";
    } } //自己写比较器
    class ProduceComparatora implements Comparator{ @Override
    public int compare(Object o1, Object o2) {
    //按照商品价格排序
    double price1=((Produce)o1).price;
    double price2=((Produce)o2).price;
    if(price1==price2){
    return 0;
    }else if(price1>price2){
    return 1;
    }else{
    return -1;
    } }
    }

Day09_46_Set集合_SortedSet03的更多相关文章

  1. java基础集合经典训练题

    第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...

  2. .Net多线程编程—并发集合

    并发集合 1 为什么使用并发集合? 原因主要有以下几点: System.Collections和System.Collections.Generic名称空间中所提供的经典列表.集合和数组都不是线程安全 ...

  3. 一起学 Java(三) 集合框架、数据结构、泛型

    一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...

  4. 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)

    建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...

  5. java基础_集合List与Set接口

    List接口继承了Collection的方法  当然也有自己特有的方法向指定位置添加元素   add(索引,添加的元素); 移除指定索引的元素   remove(索引) 修改指定索引的元素   set ...

  6. Java基础Collection集合

    1.Collection是所有集合的父类,在JDK1.5之后又加入了Iterable超级类(可以不用了解) 2.学习集合从Collection开始,所有集合都继承了他的方法 集合结构如图:

  7. 轻量级“集合”迭代器-Generator

    Generator是PHP 5.5加入的新语言特性.但是,它似乎并没有被很多PHP开发者广泛采用.因此,在我们了解PHP 7对Generator的改进之前,我们先通过一个简单却显而易见的例子来了解下G ...

  8. Asp.net MVC 传递数据 从前台到后台,包括单个对象,多个对象,集合

    今天为大家分享下 Asp.net MVC 将数据从前台传递到后台的几种方式. 环境:VS2013,MVC5.0框架 1.基本数据类型 我们常见有传递 int, string, bool, double ...

  9. 这些.NET开源项目你知道吗?.NET平台开源文档与报表处理组件集合(三)

    在前2篇文章这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧 和这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,大伙热情高涨.再次拿出自己的私货,在.NET平台 ...

随机推荐

  1. c语言:分治算法之大数相乘

    我们把整数A由规模n分为n1和n2,把整数B由规模m分为m1和m2,如下图: 则A分为n1位的A1和n2位的A1,B分为m1位的B1和m2位的B2,如下式所示: 以此类推,我们可以把A1.A2.B1. ...

  2. 若依管理系统RuoYi-Vue(三):代码生成器原理和实战

    历史文章 若依管理系统RuoYi-Vue(一):项目启动和菜单创建 若依管理系统RuoYi-Vue(二):权限系统设计详解 本篇文章将会讲解ruoyi-vue系统下代码生成器的使用.原理分析以及将这部 ...

  3. Python基础语法函数

    函数是什么 Python中的函数与数学中的函数不同,它不再只是公式,而是实实在在有着自己特定功能的代码.其实在潜移默化中我们已经有所接触了. 比如print()函数,range()函数,type()函 ...

  4. 如何读写拥有命名空间xmlns 属性的Xml文件(C#实现)

    我们在进行C#项目Xml读写开发时经常遇到一些读写问题,今天我要介绍的是遇到多个命名空间xmlns属性时如何读写此类文件. 比如下面这个Xml文件: <?xml version="1. ...

  5. 《C++ Primer》笔记 第8章 IO库

    iostream定义了用于读写流的基本类型,fstream定义了读写命名文件的类型,sstream定义了读写内存string对象的类型. 标准库使我们能忽略这些不同类型的流之间的差异,这是通过继承机制 ...

  6. Oracle VM VirtualBox下创建CentOS虚拟系统

    下载镜像 创建虚拟电脑 点击新建,输入服务器命名(根据自己喜好),选择好类型和版本(我下载的是64位的CentOS系统,所以选择类型为Linux,版本为其他版本). 修改内存大小 系统建议为512M, ...

  7. Windows下用户手册

      (1)net user(查看系统用户) (2)net user 用户名(查看具体某个系统用户详细信息) (3)net user 用户名 密码 /add(在本地组成员创建新用户,此时为Users组) ...

  8. Educational Codeforces Round 98 (Rated for Div. 2)

    A 如果\(n = m\),答案为\(2 \times n\):如果\(n \ne m\),答案为\(2 \times max(n,m) - 1\) #include <bits/stdc++. ...

  9. rest framework ViewSet

    ViewSets 路由选择确定要用于一个请求哪个控制器之后,控制器负责做出请求的感并产生相应的输出. - Ruby on Rails的文档 Django的REST框架允许你的逻辑一组在一个类中的相关意 ...

  10. JavaScript快速上手

    引入JavaScript项目 在html中 <!DOCTYPE html> <html lang="en"> <head> <meta c ...