当前位置: 首页 > news >正文

快速建站服务济南做网站公司xywlcn

快速建站服务,济南做网站公司xywlcn,建筑信号工,网站建设维护公司地址迭代器模式(Iterator Pattern)是一种行为型设计模式,它提供了一种顺序访问聚合对象(如列表、树等集合结构)中元素的方法,而无需暴露其底层实现细节。通过将遍历逻辑与集合本身解耦,迭代器模式使…
  • 迭代器模式(Iterator Pattern)是一种行为型设计模式,它提供了一种顺序访问聚合对象(如列表、树等集合结构)中元素的方法,而无需暴露其底层实现细节。通过将遍历逻辑与集合本身解耦,迭代器模式使得集合可以更灵活地支持多种遍历方式。
  • 核心思想:
    • 解耦遍历逻辑:将遍历操作从集合类中分离出来,交给独立的迭代器对象处理。
    • 统一访问接口:为不同的集合结构(如数组、链表、树)提供一致的遍历接口。
  • 应用场景:
    • 需要遍历不同结构的集合(如数组、树、图)但希望客户端代码统一。
    • 需要支持多种遍历方式(如正序、逆序、过滤遍历)。
    • 隐藏集合的内部实现,提供安全的访问接口。
package mainimport "fmt"// 迭代器接口
type Iterator interface {HasNext() boolNext() interface{}
}// 集合接口
type Aggregate interface {Iterator() Iterator
}// 具体集合(切片封装)
type ConcreteAggregate struct {items []interface{}
}func NewConcreteAggregate(items []interface{}) *ConcreteAggregate {return &ConcreteAggregate{items: items}
}// 创建迭代器
func (a *ConcreteAggregate) Iterator() Iterator {return &ConcreteIterator{aggregate: a,index:     0,}
}// 具体迭代器
type ConcreteIterator struct {aggregate *ConcreteAggregateindex     int
}func (i *ConcreteIterator) HasNext() bool {return i.index < len(i.aggregate.items)
}func (i *ConcreteIterator) Next() interface{} {if !i.HasNext() {return nil}val := i.aggregate.items[i.index]i.index++return val
}func main() {// 使用示例agg := NewConcreteAggregate([]interface{}{"A", "B", 123, true})iterator := agg.Iterator()for iterator.HasNext() {fmt.Println(iterator.Next())}
}
package mainimport "fmt"// 泛型迭代器接口
type Iterator[T any] interface {HasNext() boolNext() T
}// 泛型集合接口
type Aggregate[T any] interface {Iterator() Iterator[T]
}// 具体集合(泛型切片)
type SliceAggregate[T any] struct {items []T
}func NewSliceAggregate[T any](items []T) *SliceAggregate[T] {return &SliceAggregate[T]{items: items}
}func (a *SliceAggregate[T]) Iterator() Iterator[T] {return &SliceIterator[T]{slice: a.items,index: 0,}
}// 具体迭代器(泛型)
type SliceIterator[T any] struct {slice []Tindex int
}func (i *SliceIterator[T]) HasNext() bool {return i.index < len(i.slice)
}func (i *SliceIterator[T]) Next() T {if !i.HasNext() {var zero Treturn zero}val := i.slice[i.index]i.index++return val
}func main() {// 使用示例(字符串类型)strAgg := NewSliceAggregate([]string{"Hello", "Golang", "!"})strIter := strAgg.Iterator()for strIter.HasNext() {fmt.Println(strIter.Next())}// 使用示例(整数类型)intAgg := NewSliceAggregate([]int{1, 2, 3})intIter := intAgg.Iterator()for intIter.HasNext() {fmt.Println(intIter.Next())}
}
  • 迭代器模式要求集合类提供一个iterator方法,供别人遍历集合中的元素。
  • 迭代器模式不关心集合内部的数据结构,只要求通过next方法进行遍历。
  • 迭代器模式提高了代码的可读性和可维护性,使得遍历操作更加统一和规范

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • ConcurrentHashMap迭代器的核心成员变量包括要遍历的对象和内部存储的keys。
  • 通过二维数组或切片固定key的顺序,方便通过next方法遍历。
  • 构造函数初始化迭代器对象,包括设置要迭代的对象和keys。
  • next方法检查边界条件,通过递归处理空行情况,返回下一个key和value。

在这里插入图片描述

  • 迭代器模式提供了一种规范和要求,使得不同数据结构的遍历操作更加统一。
  • 通过接口定义行为规范,使得函数可以接受不同类型的迭代器参数。
  • 迭代器模式提高了代码的可读性和可维护性,使得遍历操作更加简洁和高效。
http://www.dtcms.com/a/580097.html

相关文章:

  • 同域名网站改版需要把之前网站里的文章都拷贝过来吗?做平行进口的汽车网站
  • 天猫网站建设可行性分析筑楼人官方网
  • 公司网站的重要性a站免费最好看的电影片推荐
  • 在百度做网站需要什么资料网站建设表格的属性
  • 微信网站页面设计建设网站商城后台系统
  • 做环评需要关注哪些网站陕西住房城乡建设厅网站
  • 简单网站制作教程怎么做网站数据分析
  • 石家庄哪里有做网站的南昌企业自助建站
  • 美食攻略网站建设课程设计注册免费的网站有吗
  • 安阳网站怎么优化威海网站定制
  • 建站行业有哪些桂林生活网招聘
  • 泉州网站排名优化教育行业手机wap网站
  • 彩票网站的建设网络推广外包公司干什么的
  • 企业网站 建设 流程温岭做鞋子的网站
  • 创意设计公司架构陕西seo排名
  • 机械设备网站源码学会网站制作要多久
  • 一流的企业网站建设wordpress 不能查看站点
  • 在建设局网站上怎么样总监解锁网页设计6种布局方式
  • 做网站多少钱 网络服务创业谷网站建设规划
  • 吉水县建设局网站网站规划应遵循的原则有哪些
  • 公司网站建设一般要多少钱asp源码下载
  • 江门微信网站建设东莞企业网站建设开发
  • 如何建立网站赚钱互联网创业项目
  • 重庆奉节网站建设公司哪家专业网站教程制作
  • 整站优化包年wordpress前台构架图
  • 公司网站开发费分录是h5网页制作方法
  • 黄埭网站建设网站图片放大特效怎么做
  • 百度站内搜索 wordpress中国十大erp公司
  • 合肥高端网站建设广州网站建设推广公司
  • 网站改版会影响排名吗蚌埠网站建设蚌埠