00078_迭代器

1、迭代器的概述

  (1)java中提供了很多个集合,它们在存储元素时,采用的存储方式不同。我们要取出这些集合中的元素,可通过一种通用的获取方式来完成;

  (2)Collection集合元素的通用获取方式:在取元素之前先要判断集合中有没有元素,如果有,就把这个元素取出来,继续在判断,如果还有就再取出出来。一直把集合中的所有元素全部取出。这种取出方式专业术语称为迭代;

  (3)每种集合的底层的数据结构不同,例如ArrayList是数组,LinkedList底层是链表,但是无论使用那种集合,我们都会有判断是否有元素以及取出里面的元素的动作,那么Java为我们提供一个迭代器定义了统一的判断元素和取元素的方法。

2、迭代器的实现原理

  /*
     *  集合中的迭代器:
     *    获取集合中元素方式
     *  接口 Iterator : 两个抽象方法
     *     boolean hasNext() 判断集合中还有没有可以被取出的元素,如果有返回true
     *     next() 取出集合中的下一个元素
     *
     *  Iterator接口,找实现类.
     *    Collection接口定义方法
     *       Iterator  iterator()
     *    ArrayList 重写方法 iterator(),返回了Iterator接口的实现类的对象
     *    使用ArrayList集合的对象
     *     Iterator it =array.iterator(),运行结果就是Iterator接口的实现类的对象
     *     it是接口的实现类对象,调用方法 hasNext 和 next 集合元素迭代
     */

3、迭代器的代码实现

 1  public class IteratorDemo {
 2         public static void main(String[] args) {
 3           Collection<String> coll = new ArrayList<String>();
 4           coll.add("abc1");
 5           coll.add("abc2");
 6           coll.add("abc3");
 7           coll.add("abc4");
 8           //迭代器,对集合ArrayList中的元素进行取出
 9
10           //调用集合的方法iterator()获取出,Iterator接口的实现类的对象
11           Iterator<String> it = coll.iterator();
12           //接口实现类对象,调用方法hasNext()判断集合中是否有元素
13           //boolean b = it.hasNext();
14           //System.out.println(b);
15           //接口的实现类对象,调用方法next()取出集合中的元素
16           //String s = it.next();
17           //System.out.println(s);
18
19           //迭代是反复内容,使用循环实现,循环的条件,集合中没元素, hasNext()返回了false
20           while(it.hasNext()){
21             String s = it.next();
22             System.out.println(s);
23           }
24
27         }
28       }

4、迭代器的执行过程

  (1)迭代器的原理

 1 while(it.hasNext()) {
 2             System.out.println(it.next());
 3        }
 4
 5        //cursor记录的索引值不等于集合的长度返回true,否则返回false
 6          public boolean hasNext() {
 7            return cursor != size; //cursor初值为0
 8
 9          }
10
11         //next()方法作用:
12         //①返回cursor指向的当前元素
13         //②cursor++
14         public Object next() {
15                  int i = cursor;
16                  cursor = i + 1;
17                  return  elementData[lastRet = i];
18
19              }

  (2)for循环迭代写法

for (Iterator<String> it2 = coll.iterator(); it2.hasNext();  ) {
         System.out.println(it2.next());
       } 

5、集合迭代中的转型

  (1)在使用集合时,我们需要注意以下几点:

  集合中存储其实都是对象的地址;

  集合中可以存储基本数值吗?jdk1.5版本以后可以存储了;

  因为出现了基本类型包装类,它提供了自动装箱操作(基本类型?对象),这样,集合中的元素就是基本数值的包装类对象。

  (2)存储时提升了Object。取出时要使用元素的特有内容,必须向下转型

 1  Collection coll = new ArrayList();
 2      coll.add("abc");
 3      coll.add("aabbcc");
 4      coll.add("shitcast");
 5      Iterator it = coll.iterator();
 6      while (it.hasNext()) {
 7       //由于元素被存放进集合后全部被提升为Object类型
 8      //当需要使用子类对象特有方法时,需要向下转型
 9       String str = (String) it.next();
10       System.out.println(str.length());
11      }

  注意:如果集合中存放的是多个对象,这时进行向下转型会发生类型转换异常。

  (3)Iterator接口也可以使用<>来控制迭代元素的类型的。代码演示如下:

 1 Collection<String> coll = new ArrayList<String>();
 2      coll.add("abc");
 3      coll.add("aabbcc");
 4      coll.add("shitcast");
 5      Iterator<String> it = coll.iterator();
 6      while (it.hasNext()) {
 7       String str =  it.next();
 8      //当使用Iterator<String>控制元素类型后,就不需要强转了。获取到的元素直接就是String类型
 9       System.out.println(str.length());
10      }
时间: 2024-10-09 11:26:43

00078_迭代器的相关文章

Day4 - 迭代器&amp;生成器、装饰器、Json &amp; pickle 数据序列化、软件目录结构规范

---恢复内容开始--- 本节内容 迭代器&生成器 装饰器 Json & pickle 数据序列化 软件目录结构规范 作业:ATM项目开发 1.列表生成式,迭代器&生成器 列表生成式 需求:列表a = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9],要求把列表里的每个值加1 1 a = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 2 b = [] 3 for i in a: 4 b.append(i+1) 5 a = b 6 print(a) 普通青

装饰器、生成器、迭代器

装饰器的前奏 装饰器:本质是函数 功能:就是装饰成其他函数  就是为其他函数添加附加功能的 高阶函数+嵌套函数=装饰器 原则:1.不能修改被装饰的函数的源代码 2.不能修改被装饰的函数的调用方式 总结一句话:装饰器对被装饰的函数是完全透明的 实现装饰器的只是储备: 1.函数名即"变量"   将函数体赋值给变量   和内存回收机制一样 2.高阶函数 2.1.把函数名作为实参传递给形参(可返回被修饰函数的地址)(不修改源代码的情况可添加新的功能) 2.2返回值中包含函数地址(不修改函数的调

Vector容器 和 iteration 迭代器

vector容器 vector是同一种类型的对象的集合,每个对象都有一个对应的整数索引值.和string对象一样,标准库负责管理存储元素的相关内存.我们把vector称为容器,是因为它可以包含其他对象.一个容器中的所有对象都必须是同一种类型的. 使用vector之前,必须包含相应的头文件.#include <vector> using std::vector; vector是一个类模板(class template).模板允许程序员编写单个类或函数定义,这个类和函数定义可用于不同的数据类型上.

Python高级特性:迭代器和生成器 -转

在Python中,很多对象都是可以通过for语句来直接遍历的,例如list.string.dict等等,这些对象都可以被称为可迭代对象.至于说哪些对象是可以被迭代访问的,就要了解一下迭代器相关的知识了. 迭代器 迭代器对象要求支持迭代器协议的对象,在Python中,支持迭代器协议就是实现对象的__iter__()和next()方法.其中__iter__()方法返回迭代器对象本身:next()方法返回容器的下一个元素,在结尾时引发StopIteration异常. __iter__()和next()

python-学习笔记之-Day5 双层装饰器 字符串格式化 python模块 递归 生成器 迭代器 序列化

1.双层装饰器 #!/usr/bin/env python # -*- coding: utf-8 -*- # author:zml LOGIN_INFO = False IS_ADMIN = False   def check_log(func): def inner(): res = func() if LOGIN_INFO: print('验证成功!') return res else: print('验证失败!') return inner   def check_admin(func)

Python基础教程(第九章 魔法方法、属性和迭代器)

本文内容全部出自<Python基础教程>第二版,在此分享自己的学习之路. ______欢迎转载:http://www.cnblogs.com/Marlowes/p/5437223.html______ Created on Marlowes 在Python中,有的名称会在前面和后面都加上两个下划线,这种写法很特别.前面几章中已经出现过一些这样的名称(如__future__),这种拼写表示名字有特殊含义,所以绝不要在自己的程序中使用这样的名字.在Python中,由这些名字组成的集合所包含的方法称

迭代器

创建迭代器最常用的方法是对IEnumerator接口实现GetEnumerator方法. public class Family : System.Collections.IEnumerable { string[] myFamily = {“父亲”,”母亲”,”弟弟”,”妹妹”}; public System.Collections.IEnumerator GetEnumerator() { for(int i=0;i<myFamily.Length;i++) { yield return m

LeetCode OJ:Peeking Iterator(peeking 迭代器)

Given an Iterator class interface with methods: next() and hasNext(), design and implement a PeekingIterator that support the peek() operation -- it essentially peek() at the element that will be returned by the next call to next(). Here is an exampl

JavaScript设计模式 - 迭代器模式

迭代器模式是指提供一种方法顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示. 迭代器模式可以把迭代的过程从业务逻辑中分离出来,在使用迭代器模式之后,即使不关心对象的内部构造,也可以按顺序访问其中的每个元素 许多浏览器都支持 Javascript 的 Array.prototype.forEach 迭代器可以分为 内部迭代器 和 外部迭代器 一.jQuery 中的迭代器 1 $.each( [1,2,3,4], function (i, n) { 2 console.log( "当