zoukankan      html  css  js  c++  java
  • 迭代器模式

    一、内容

    提供一种方法顺序访问一个聚合函数一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示

    二、实现方法

    迭代器内部实现:__iter__、__next__方法

    三、代码实现

    class LinkList:
        """链表 头结点保存链表的长度"""
        class Node:
            def __init__(self, item=None):
                self.item = item
                self.next = None
    
        class LinkListIterator:
            def __init__(self, node):
                self.node = node
            def __next__(self):
                if self.node:
                    cur_node = self.node
                    self.node = cur_node.next
                    return cur_node.item
                else:
                    raise StopIteration
            def __iter__(self):
                return self
    
        def __init__(self, iterable=None):
            self.head = LinkList.Node(0)
            self.tail = self.head
            self.extend(iterable)
    
        def append(self, obj):
            s = LinkList.Node(obj)
            self.tail.next = s
            self.tail = s
    
        def extend(self, iterable):
            for obj in iterable:
                self.append(obj)
            self.head.item += len(iterable)
    
        def __iter__(self):
            return self.LinkListIterator(self.head.next)
    
        def __len__(self):
            return self.head.item
    
        def __str__(self):
            return "<<"+", ".join(map(str, self))+">>"
    
    
    
    li = [i for i in range(100)]
    print(li)
    lk = LinkList(li)
    # for i in lk:
    #     print(i)
    
    print(lk)
    # print(len(lk))
  • 相关阅读:
    流媒体服务器搭建
    netcore问题总结
    Linux(Debian)网卡设置
    windows服务器让WEB通过防火墙的问题
    经典算法一 --- 过桥问题
    MySQL字段属性介绍
    什么是流程控制
    终于决定了,转行。
    浅析Openflow
    JavaScript 中 this 的详解
  • 原文地址:https://www.cnblogs.com/morgana/p/8496303.html
Copyright © 2011-2022 走看看