迭代器:Iterator接口

//获取集合中的对象
Iterator<E> iterator()

interface Iterator
{
  boolean hasNext();
  Object next();
}
//遍历

Iterator ite = col.iterator();
while(ite.hasNext())
{
  //获得一个对象
  Object obj = ite.next();
  System.out.println(obj);
}
for(int i = 0;i<col.size();i++)
{ } for(Iterator ite = col.iterator();ites.hasNext());)
{ }

集合:Collection接口

  可以存储不同类型的对象,而且随着存储的对象的增加容量自动扩大

  Collection:
    **iterator():获取集合中的对象
    --List:
      存储的对象是有序的
      集合中对象的顺序和添加对象的顺序是一致的,可以重复的
      List特有的方法都是可以操作下标的方法
      --ArrayList:
        底层使用的数据结构是数组
        线程不安全的
        查找速度快,增删速度慢
      --LinkedList:
        底层使用的数据结构是链表
        线程不安全的
        查找速度慢,增删速度快
      --Vector:
        底层使用的数据结构是数组
        线程安全的(被ArrayList替代)
        查找速度快,增删速度慢,被ArrayList替代
   --Set:
    存储的对象是无序的,不可重复的
    --HashSet:
      底层使用的数据结构是哈希表
      线程不安全
    --TreeSet:
      底层使用的数据结构是二叉树,可以排序
      线程不安全

  Vector: 动态数组

    早期使用Enumeration接口进行枚举

Enumeration e = v.elements();

while(e.hasMoreElements())
{
Object obj = e.nextElements();
System.out.println(obj);
}

LinkedList:

jdk1.5 jdk1.6之后

addFirst

addLast

offerFirst

offerLast

getFirst:获取的元素不存在出现NoSuchElementException

getLast

peekFirst:获取的元素不存在返回null

peekLast

removeFirst

removeLast

linkFirst

linkLast

  ArrayList:

1 去掉集合中重复的对象

  新建一个list2
  遍历旧集合
    如果list2中不包含这个对象,添加
      contains(obj)
    如果list2中包含,不添加

 2 contains判断是否包含某个对象的依据?

   依据boolean equals(Object obj)方法的返回值

 

 3 直接输出List<Class>的话,输出的是Class的hash值

  解决:
    在class中重写toString():

  
    public String toString()
    {
      return ...;
    }

 

 4 去掉List<class>中相同内容的class

  在class中重写equals()

  public boolean equals(Object obj)

  {

    if(!(obj instanceof Student))//如果obj不是Student类型
       throws new RuntimeException("类型错误");

    Student stu = (Student)obj;

    return this.age == stu.age && this.name.equals(stu.name);
  
   }

 

  HashSet:

1 在使用add方法添加对象时就保证了对象的唯一

 2 HashSet无序的原因

  数据结构是哈希表,根据哈希算法得到位置,导致的无序

3 HashSet保证对象唯一的方式
 在添加对象时,先比较得到对象的hash值和集合中对象的hash值分别进行比较

 int hashCode()
  如果和所有对象的hash值都不相同,将对象直接添加到集合
 
 boolean equals()

  如果相同,使用equals()方法比较内存地址是否相同

     如果相同,认为是同一对象,不添加

     如果不同,认为是不同的对象,加入集合

 4 去掉Hash<class>中相同内容的class

  在class中重写hashCode 和 equals方法

  public int hashCode()
  {
    return name.hashCode() + age * 33;
  }

  public boolean equals(Object obj)
  {
    if(!(obj instanceof Student))//如果obj不是Student类型
      throws new RuntimeException("类型错误");

    Student stu = (Student)obj;

    return this.age = stu.age && this.name.equals(stu.name);
  }

   TreeSet:

1 在使用add方法添加对象时会对添加的对象进行排序
  排序方式一:
    集合中对象所属的类实现了Comparable接口中的compareTo()方法
  排序方式二:
    自定义排序方法 2 TreeSet保证对象唯一的方式:
  集合中对象所属的类实现了Comparable接口中的compareTo()方法

 3 去掉TreeSet<class>中相同内容的class

   在class中重写compareTo()

    public int compareTo(Object obj)
    {

      if(!(obj instanceof Student))//如果obj不是Student类型
        throws new RuntimeException("类型错误");

      Student stu = (Student)obj;

      int num = this.age - stu.age;

      return num == 0 ? this.name.compatrTo(stu.name) : num;
    }

Java 迭代器 工具类的更多相关文章

  1. Java Properties工具类详解

    1.Java Properties工具类位于java.util.Properties,该工具类的使用极其简单方便.首先该类是继承自 Hashtable<Object,Object> 这就奠 ...

  2. Java json工具类,jackson工具类,ObjectMapper工具类

    Java json工具类,jackson工具类,ObjectMapper工具类 >>>>>>>>>>>>>>> ...

  3. Java日期工具类,Java时间工具类,Java时间格式化

    Java日期工具类,Java时间工具类,Java时间格式化 >>>>>>>>>>>>>>>>>&g ...

  4. Java并发工具类 - CountDownLatch

    Java并发工具类 - CountDownLatch 1.简介 CountDownLatch是Java1.5之后引入的Java并发工具类,放在java.util.concurrent包下面 http: ...

  5. MinerUtil.java 爬虫工具类

    MinerUtil.java 爬虫工具类 package com.iteye.injavawetrust.miner; import java.io.File; import java.io.File ...

  6. MinerDB.java 数据库工具类

    MinerDB.java 数据库工具类 package com.iteye.injavawetrust.miner; import java.sql.Connection; import java.s ...

  7. 小记Java时间工具类

    小记Java时间工具类 废话不多说,这里主要记录以下几个工具 两个时间只差(Data) 获取时间的格式 格式化时间 返回String 两个时间只差(String) 获取两个时间之间的日期.月份.年份 ...

  8. Java Cookie工具类,Java CookieUtils 工具类,Java如何增加Cookie

    Java Cookie工具类,Java CookieUtils 工具类,Java如何增加Cookie >>>>>>>>>>>>& ...

  9. UrlUtils工具类,Java URL工具类,Java URL链接工具类

    UrlUtils工具类,Java URL工具类,Java URL链接工具类 >>>>>>>>>>>>>>>&g ...

随机推荐

  1. JSP--TOMCAT-MYSQL web页面查询

    queryStudent.jsp代码如下 <%@ page language="java" contentType="text/html; charset=gb23 ...

  2. Qt 获取组合键 键盘按住某键 鼠标组合实现

    #include "mainwindow.h" #include <QDebug> #include <QKeyEvent> #include <QM ...

  3. 判断颜色信息-RGB2HSV(opencv)

    前言 项目车号识别过程中,车体有三种颜色黑车黑底白字.红车红底白字.绿车黄底绿字,可以通过判断车体的颜色信息,从而判断二值化是否需要反转,主要是基于rgb2hsv函数进行不同颜色的阈值判断. matl ...

  4. [LeetCode&Python] Problem 700. Search in a Binary Search Tree

    Given the root node of a binary search tree (BST) and a value. You need to find the node in the BST ...

  5. BZOJ5091: [Lydsy1711月赛]摘苹果【期望DP】

    Description 小Q的工作是采摘花园里的苹果.在花园中有n棵苹果树以及m条双向道路,苹果树编号依次为1到n,每条道路的两 端连接着两棵不同的苹果树.假设第i棵苹果树连接着d_i条道路.小Q将会 ...

  6. Heap Operations 优先队列

    Petya has recently learned data structure named "Binary heap". The heap he is now operatin ...

  7. python list 的查找, 搜索, 定位, 统计

    Python中是有查找功能的,四种方式:in.not in.count.index,前两种方法是保留字,后两种方式是列表的方法. 下面以a_list = ['a','b','c','hello'],为 ...

  8. prisma 服务器端订阅试用

      graphql 协议是支持数据的实时订阅功能的(一般基于websocket 进行实现) prisma 支持客户端订阅以及服务器端订阅(类似webhook),可以方便将 数据推送后端服务 目的 pr ...

  9. sqlserver中numeric字段截取

    方法一:convert(float,字段名) as 别名 select convert(float,round(10.123232,2)) 结果:10.12 select convert(float, ...

  10. Hadoop集群搭建笔记

    1.安装虚拟机 VMware workstation CentOS 镜像 安装Linux虚拟机:(在Win7上) 1)安装VMwareWorkstations(可修改配置) 2)添加CentOS镜像( ...