Iterator 接口、重写 hashCode()和equals()原则、Comparable和Comparator比较器

本文详细介绍了Java中如何使用Iterator接口遍历集合,包括Iterator的remove方法及其注意事项。接着讨论了重写hashCode()和equals()方法的原则,并强调了两者的一致性。最后,讲解了Comparable和Comparator接口在排序中的作用,以及如何通过它们比较对象的相等性。
摘要由CSDN通过智能技术生成

继上一篇文章https://blog.csdn.net/weixin_44514198/article/details/105482625整理了collection接口的一些内容,下面介绍上一篇文章没有介绍到的一些问题

1. 使用 Iterator 接口遍历集合元素

  • Collection接口继承了java.lang.Iterable接口,该接口有一个iterator()方法,那么所有实现了Collection接口的集合类都有一个iterator()方法,用以返回一个实现了 Iterator接口的对象。
  • Iterator仅用于遍历集合,Iterator 本身并不提供承装对象的能力。如果需要创建 Iterator 对象,则必须有一个被迭代的集合。
  • 集合对象每次调用iterator()方法都得到一个全新的迭代器对象,默认游标都在集合 的第一个元素之前。
    在调用it.next()方法之前必须要调用it.hasNext()进行检测。若不调用,且 下一条记录无效,直接调用it.next()会抛出NoSuchElementException异常
//hasNext():判断是否还有下一个元素 
while(iterator.hasNext()){
   
 //next():①指针下移②将下移以后集合位置上的元素返回 
 System.out.println(iterator.next());
  }

Iterator接口remove()方法

Iterator iter = coll.iterator();//回到起点 
while(iter.hasNext()){
   
 Object obj = iter.next(); 
 if(obj.equals("Tom")){
   
  iter.remove(); 
  }
   }

  • Iterator可以删除集合的元素,但是是遍历过程中通过迭代器对象的remove方 法,不是集合对象的remove方法。

  • 如果还未调用next()或在上一次调用 next 方法之后已经调用了 remove 方法,
    再调用remove都会报IllegalStateException

2. 重写 hashCode() 方法的基本原则

  • 在程序运行时,同一个对象多次调用 hashCode() 方法应该返回相同的值。 当两个对象的 equals() 方法比较返回

  • true 时,这两个对象的 hashCode() 方法的返回值也应相等。 对象中用作 equals() 方法比较的

  • Field,都应该用来计算 hashCode 值。

3. 重写 equals() 方法的基本原则

  • 当一个类有自己特有的“逻辑相等”概念,当改写equals()的时候,总是
    要改写hashCode(),根据一个类的equals方法(改写后),两个截然不
    同的实例有可能在逻辑上是相等的,但是,根据Object.hashCode()方法, 它们仅仅是两个对象。
    因此,违反了“相等的对象必须具有相等的散列码”
  • 结论:重写equals方法的时候一般都需要同时重写hashCode方法。通
    常参与计算hashCode的对象的属性也应该参与到equals()中进行计算。

4. java.lang.Comparable和java.util.Comparator比较器

在java中指定排序规则的方式只有两种:(java.lang.Comparable和java.util.Comparator)。为对集合中的元素按照一定的规则进行排序。

a) java.lang.Comparable接口

也称为内部比较器,存入TreeSet中的类实例必须实现java.lang.Comparable接口。这样在集合中的对象就可自动排序。Arrays.sort(Object[] a) 数组中的所有元素都必须实现 Comparable 接口。
Order:

import java.util.Date;

public class Order implements Comparable<Order>{
   
    private String orderNo;
    private int amout;
    private double totalPrice;
    private Date orderDate;

    public Order(){
   }

    /**
     *
     * @param orderNo 订单编号
     * @param amout 订单数量
     * @param totalPrice 订单总价
     * @param orderDate 订单日期
     */
    public Order(String orderNo, int amout, double totalPrice, Date orderDate) {
   
        this.orderNo = orderNo;
        this.amout = amout;
        this.totalPrice = totalPrice;
        this.orderDate = orderDate;
    }

    public String getOrderNo() {
   
        return orderNo;
    }

    public void setOrderNo(String orderNo) {
   
        this.orderNo = orderNo;
    }

    public int getAmout() {
   
        return amout;
    }

    public void setAmout(int amout) {
   
        this.amout = amout;
    }

    public double getTotalPrice() {
   
        return totalPrice;
    }

    public void setTotalPrice(double totalPrice) {
   
        this.totalPrice = totalPrice;
    }

    public Date getOrderDate() {
   
        return orderDate;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值