设计模式---迭代(遍历)

本文深入探讨了迭代模式的核心概念,即如何通过内部类实现集合元素的遍历而不暴露其内部结构,提供了一种优雅的访问集合元素的方式。通过具体代码示例,展示了如何在Java中实现迭代模式,包括定义迭代器接口、创建包含迭代器的类以及在主函数中使用迭代器进行遍历。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

其实很多东西手写或敲不出来,是不知道要干嘛。比如迭代模式是个啥,说出啥,估计很多人都写得出来。

迭代模式:不暴露里面的东西,循环遍历里面的东西出来。遍历这个操作,又不暴露,那就遍历这个操作搞成内部类了。作为这家伙的一个属性即可。这属性供外部用就行了。那遍历在内部类里面怎么设计你自己想了。jdk的就是hasnext和getnext,里面加个指针索引即可。搞定迭代遍历。

 

public interface IteratorY<E>{
        boolean hashNext();
        E getNext();
    }
    public interface ContainY{
        IteratorY getIteratorY();
    }
    public class Target implements ContainY{
        
        String[] yuan = {"a","b","c","d"};
        public class MyIteratorY implements IteratorY<String>{
            int point = -1;
            @Override
            public boolean hashNext() {
                if(point == yuan.length){
                    return false;                    
                }else{
                    point = point + 1;
                    return true;
                }
            }

            @Override
            public String getNext() {
                if(point == yuan.length){
                    return "";
                }else{
                    return yuan[point];
                }
            }
            
        }
        @Override
        public IteratorY getIteratorY() {
            return new MyIteratorY();
        }
    }
    
    public static void main(String[] args) throws Exception {
        test.IteratorY iteratory = new test().new Target().getIteratorY();
        while(iteratory.hashNext()){
            System.out.println(iteratory.getNext());
        }

   }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值