Comparable 和 Comparator

Comparable 和 Comparator 是两个关系不大的类,其分别侧重于不同的方面。

其中,接口 Comparable<T> 强行对实现它的每个类的对象进行整体排序。

这种排序被称为类的自然排序,类的 compareTo 方法被称为它的自然比较方法

Date dt = new Date();
// 默认计算从标准时间为止的毫秒数,也可以指定初始时间
Date dt2 = new Date(2222L);
// -1 表示小于,0表示等于,1表示相等
System.out.println(dt.compareTo(dt2)); // 1

对于接口 Comparator<T> ,则实现了一个比较函数,

List<Integer> lt = new ArrayList<>();
lt.add(2);
lt.add(8);
lt.add(3); lt.sort((t1, t2) -> t1 < t2 ? 1 : (t1.equals(t2) ? 0 : -1)); /*lt.sort(new Comparator<Integer>() {*/
/* @Override*/
/* public int compare(Integer t1, Integer t2) {*/
/* return t1 < t2 ? 1 : (t1.equals(t2) ? 0 : -1);*/
/* }*/
/*});*/ System.out.println(lt);

Iterable 和 Iterator

接口 Iterable<T> 实现这个接口允许对象成为 "foreach" 语句的目标。

注意:由于 java中没有 Array类,所以数组中没有实现 Iterable 接口,但是它可以使用 foreach方式遍历。

而其核心方法就是 iterator ,该方法的返回值为 Iterator<T> 对象。通过Iterator 对象的hasNext()与 next() 方法实现遍历。

从某种角度来说,foreach 是 iterator的简单语法糖(一种形式):

List<Integer> lt = new ArrayList<>(4);
lt.add(2);
lt.add(9);
lt.add(3); for (int i : lt) {
System.out.println(i);
} Iterator<Integer> itor = lt.iterator();
while (itor.hasNext()) {
Integer i = itor.next();
System.out.println(i);
}

  

注意:当直接使用 iterator 时,注意在 while方法体内不能调用对集合调用任何 modify形式的方法 (如 add,remove,clear 等方法),否则抛出 ConcurrentModificationException 异常,但是可以调用 iterator 对象的本身的 remove方法。

foreach 同理,但可以在只使用 while 遍历,而不使用 iterator的循环中使用 modify形式的方法。

java 中的 Comparable 和 Comparator 与 Iterable 和 Iterator的更多相关文章

  1. 【软件构造】(转)Java中的comparable和comparator

    为了方便阅读和复习,转载至此,原地址:温布利往事的博客 阅读目录 一.Comparable简介 二.Comparator简介 三.Comparable和Comparator区别比较 回到顶部 一.Co ...

  2. 来吧,一文彻底搞懂Java中的Comparable和Comparator

    大家好,我是沉默王二,今天在逛 programcreek 的时候,我发现了一些专注细节但价值连城的主题.比如说:Java 的 Comparable 和 Comparator 是兄弟俩吗?像这类灵魂拷问 ...

  3. Java基础系列-Comparable和Comparator

    原创文章,转载请标注出处:<Java基础系列-Comparable和Comparator> 一.概述         Java中的排序是由Comparable和Comparator这两个接 ...

  4. Java基础之Comparable与Comparator

    Java基础之Comparable与Comparator 一.前言: Java中实现对对象的排序一般情况下主要有以下两种实现方式(万物皆对象嘛): 对象所在的类实现Comparable 接口 定义比较 ...

  5. Java中的Comparable<T>和Comparator<T>接口

    有的时候在面试时会被问到Comparable<T>和Comparator<T>的区别(或者Java中两种排序功能的实现区别). 1) 在使用普通数组的时候,如果想对数据进行排序 ...

  6. Java中的comparable接口和Comparator接口的区别

    一.comparable和Comparator的区别 1.Comparable和Comparator都是用来实现集合中元素的比较.排序的. 2.Comparable是在类内部定义的方法实现的排序,位于 ...

  7. Java学习之Comparable与Comparator的区别

    Comparable & Comparator 都是用来实现集合中元素的比较.排序的,只是 Comparable 是在集合内部定义的方法实现的排序,Comparator 是在集合外部实现的排序 ...

  8. java比较排序Comparable和Comparator

    1       比较排序Comparable和Comparator 1.1      接口作用说明 Comparable和Comparator都是用来实现对象的比较.排序,对比时需要实现Compara ...

  9. java中Comparatable接口和Comparator接口的区别

    1.不同类型的排序规则 .自然排序是什么?   自然排序是一种升序排序.对于不同的数据类型,升序规则不一样:   BigDecimal BigInteger Byte Double Float Int ...

随机推荐

  1. 每天一个linux命令(10):cat

    1.命令简介 cat (concatenate,连接)命令将[文件]或标准输入组合输出到标准输出,如果没有指定文件,或者文件为"-",则从标准输入读取. 2.用法 cat [选项] ...

  2. Android 实现登录界面和功能实例

    近期一个android小程序须要登录功能,我简单实现了一下.如今记录下来也当做个笔记,同一时候也希望能够相互学习.所以,假设我的代码有问题,还各位请提出来.多谢了! 以下.就简述一下此实例的主要内容: ...

  3. [转]awsome-java

    原文链接 Awesome Java A curated list of awesome Java frameworks, libraries and software. Contents Projec ...

  4. 51单片机stack堆栈

    一般编译器的堆栈用于保存局部变量.函数的参数.函数的返回值.中断上下文信息等.但Keil对局部变量.函数参数预先分配空间(放在静态全局变量区),Keil的堆栈只是用于保存函数嵌套调用的PC.中断上下文 ...

  5. Atitit sleep原理 node.js sleep解决方案 timer

    Atitit  sleep原理  node.js sleep解决方案  timer sleep()的实现分为三步: 1.注册一个信号signal(SIGALRM,handler).接收内核给出的一个信 ...

  6. [HDFS Manual] CH8 HDFS Snapshots

    HDFS Snapshots HDFS Snapshots 1. 概述 1.1 Snapshottable目录 1.2 快照路径 2. 带快照的更新 3. 快照操作 3.1 管理操作 3.2 用户操作 ...

  7. NetBeans使用Consolas中文乱码的解决

    1.进入jdk安装目录下/jre/lib文件夹,找到fontconfig.properties.src,拷贝为 fontconfig.properties ,修改此文件. 找到: sequence.m ...

  8. IndexedDB 教程

    IndexedDB 教程 IndexedDB 是一个基于 JavaScript 的面向对象的事务型数据库.有了 LocalStorage 和 Cookies,为什么还要推出 indexedDB 呢?其 ...

  9. [转]论SOA架构的几种主要开发方式

    面向服务架构soa以其独特的优势越来越受到企业的重视,它可以根据需求通过网络对松散耦合的粗粒度应用组件进行分布式部署.组合和使用.服务层是SOA的基础,可以直接被应用调用,从而有效控制系统中与软件代理 ...

  10. TF的模型文件

    TF的模型文件 标签(空格分隔): TensorFlow Saver tensorflow模型保存函数为: tf.train.Saver() 当然,除了上面最简单的保存方式,也可以指定保存的步数,多长 ...