【設計模式-4.5】行為型——迭代器模式

說明:本文介紹設計模式中,行為型設計模式之一的迭代器模式。

定義

迭代器模式(Iterator Pattern),也叫作游標模式(Cursor Pattern),它提供一種按順序訪問集合/容器對象元素的方法,而又無須暴露集合內部表示。迭代器模式可以為不同的容器提供一致的遍歷行為,而不用關心容器內元素的組成結構。(引自《設計模式就該這樣學》P329)

行車記錄儀場景

假設有一個行車記錄儀對象,可存儲行車記錄時的視頻,可存儲10個視頻,超出會覆蓋最早的數據,如下:

/*** 行車記錄儀*/
public class DrivingRecorder {/*** 當前記錄的位置*/private int index = -1;/*** 假設只能存儲10個視頻*/private String[] records = new String[10];/*** 存入*/public void append(String record) {// 如果當前位置已經到達末尾,就從頭開始存儲if (index == 9) {index = 0;} else {index++;}records[index] = record;}/*** 順序遍歷*/public void display() {for (int i = 0; i < 10; i++) {System.out.println(i + ":" + records[i]);}}/*** 按照存入順序逆序遍歷* 從新=>舊讀取*/public void displayByOrder() {// loopCount:是集合能存儲的數據個數,故不能大于10;// i是記錄的位置,存的時候+1,讀的時候-1,并且還要做==0判斷,如果==0,就從集合末尾開始讀;for (int i = index, loopCount = 0; loopCount < 10; i = i == 0 ? 9 : i - 1, loopCount++) {System.out.println(records[i]);}}
}

運行如下,可見存入12個視頻,把前面存儲的兩個視頻數據覆蓋了。

在這里插入圖片描述

分析
(1)無法讀取到行車記錄儀中的數據(即變量records),當然我們可以開放對應的get方法,但這樣設計遍歷和讀取數據方法不免有重復(現成的index變量還沒用上,不可惜嘛?),我們能否擴展遍歷方法,返回當前位置上的數據?;

(2)代碼不夠優雅,對于一個封閉的對象或者說容器,遍歷對象內的數據,我們是否可以考慮抽出成一個接口,定義遍歷的規范,使其他對象實現其接口。

迭代器設計

針對上面行車記錄儀場景,改造成迭代器設計模式,如下:

import java.util.Iterator;/*** 行車記錄儀(迭代器設計)*/
public class DrivingRecorderIterable implements Iterable<String> {/*** 當前記錄的位置*/private int index = -1;/*** 假設只能存儲10個視頻*/private String[] records = new String[10];/*** 存入*/public void append(String record) {// 如果當前位置已經到達末尾,就從頭開始存儲if (index == 9) {index = 0;} else {index++;}records[index] = record;}@Overridepublic Iterator<String> iterator() {return new Itr();}/*** 行車記錄儀迭代器*/private class Itr implements Iterator<String> {/*** cursor:游標,這里通過賦值拷貝一份,不要直接使用index,不然一邊讀一邊寫的時候會出錯* loopCount:是集合能存儲的數據個數,故不能大于10*/int cursor = index;int loopCount = 0;@Overridepublic boolean hasNext() {return loopCount < 10;}@Overridepublic String next() {int i = cursor;if (i == 9) {i = 0;} else {i++;}cursor = i;loopCount++;return records[i];}}
}

這里使用的接口是JDK自帶的Iterator,實現該接口的類都能使用上述方式遍歷數據。

在這里插入圖片描述

Java中的單列集合,Collection,實現了該接口,也就是說實現了Collection接口的容器,都支持這種迭代器的遍歷方式。

在這里插入圖片描述

像ArrayList

        List<String> list = new ArrayList<>();list.add("王麻子");list.add("小李子");list.add("李愛花");Iterator<String> iterator = list.iterator();while (iterator.hasNext()){System.out.println(iterator.next());}

使用場景

在《設計模式就該這樣學》(P330)這本書中,提到迭代器模式適用于以下場景:

(1)訪問一個集合對象的內容而無須暴露它的內部表示。

(2)為遍歷不同的集合結構提供一個統一的訪問接口;


結合上述行車記錄儀場景,如果你需要訪問一個對象中的數據,又不想開放對應數據的get方法,就可以考慮迭代器模式。

總結

本文介紹了行為型設計模式中的迭代器模式,參考《設計模式就該這樣學》、《秒懂設計模式》兩書,行車記錄儀場景是《秒懂設計模式》中的舉例,非常形象,容易理解。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/907641.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/907641.shtml
英文地址,請注明出處:http://en.pswp.cn/news/907641.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

鴻蒙OSUniApp自定義手勢識別與操作控制實踐#三方框架 #Uniapp

UniApp自定義手勢識別與操作控制實踐 引言 在移動應用開發中&#xff0c;手勢交互已經成為提升用戶體驗的重要組成部分。本文將深入探討如何在UniApp框架中實現自定義手勢識別與操作控制&#xff0c;通過實際案例幫助開發者掌握這一關鍵技術。我們將以一個圖片查看器為例&…

【數據結構】樹形結構--二叉樹

【數據結構】樹形結構--二叉樹 一.知識補充1.什么是樹2.樹的常見概念 二.二叉樹&#xff08;Binary Tree&#xff09;1.二叉樹的定義2.二叉樹的分類3.二叉樹的性質 三.二叉樹的實現1.二叉樹的存儲2.二叉樹的遍歷①.先序遍歷②.中序遍歷③.后序遍歷④.層序遍歷 一.知識補充 1.什…

從認識AI開始-----解密LSTM:RNN的進化之路

前言 我在上一篇文章中介紹了 RNN&#xff0c;它是一個隱變量模型&#xff0c;主要通過隱藏狀態連接時間序列&#xff0c;實現了序列信息的記憶與建模。然而&#xff0c;RNN在實踐中面臨嚴重的“梯度消失”與“長期依賴建模困難”問題&#xff1a; 難以捕捉相隔很遠的時間步之…

接地氣的方式認識JVM(一)

最近在學jvm&#xff0c;浮于表面的學了之后&#xff0c;發現jvm并沒有我想象中的那么神秘&#xff0c;這篇文章將會用接地氣的方式來說一說這些jvm的相關概念以及名詞解釋。 帶著下面兩個問題來閱讀 認識了解JVM大致有什么在代碼運行時的都在背后做了什么 JVM是個啥&#xf…

Next.js 15 與 Apollo Client 的現代集成及性能優化

Next.js 15 與 Apollo Client 的現代集成及性能優化 目錄 技術演進集成實踐性能優化應用案例未來趨勢 技術演進 Next.js 15 核心特性對開發模式的革新 Next.js 15 通過引入 App Router、服務器組件&#xff08;Server Components&#xff09;和客戶端組件&#xff08;Clie…

無人機橋梁3D建模、巡檢、檢測的航線規劃

無人機橋梁3D建模、巡檢、檢測的航線規劃 無人機在3D建模、巡檢和檢測任務中的航線規劃存在顯著差異&#xff0c;主要體現在飛行高度、航線模式、精度要求和傳感器配置等方面。以下是三者的詳細對比分析&#xff1a; 1. 核心目標差異 任務類型主要目標典型應用場景3D建模 生成…

Hive數據傾斜問題深度解析與實戰優化指南

一、數據傾斜現象的本質與危害 數據傾斜是Hive在MapReduce計算過程中,?部分Key對應的數據量遠超其他Key,導致少數Reducer任務處理時間遠高于其他任務的性能瓶頸問題。典型表現為: ?作業進度卡在99%??:99%的Reducer已完成,剩余1%持續數小時?資源利用率失衡?:部分節…

VRRP 原理與配置:讓你的網絡永不掉線!

VRRP 原理與配置&#xff1a;讓你的網絡永不掉線&#xff01; 一. VRRP 是什么&#xff0c;為什么需要它&#xff1f;二. VRRP 的核心概念三. VRRP 的工作原理四. 華為設備 VRRP 配置步驟 &#xff08;主備模式&#xff09;4.1 拓撲示例4.2 &#x1f6e0; 配置步驟 五. VRRP 配…

解決開發者技能差距:AI 在提升效率與技能培養中的作用

企業在開發者人才方面正面臨雙重挑戰。一方面&#xff0c;IDC 預測&#xff0c;到2025年&#xff0c;全球全職開發者將短缺400萬人&#xff1b;另一方面&#xff0c;一些行業巨頭已暫停開發者招聘&#xff0c;轉而倚重人工智能&#xff08;AI&#xff09;來滿足開發需求。這不禁…

痛點即爆點?如何挖掘客戶的痛點和需求?

銷售的核心在于精準洞察客戶需求與痛點&#xff0c;并運用專業能力為其提供定制化解決方案&#xff0c;從而消除客戶顧慮、解決問題&#xff0c;最終實現雙贏。而快速識別客戶痛點&#xff0c;不僅是成交的關鍵&#xff0c;更是建立專業形象、贏得客戶信任的核心能力。那么&…

云服務器如何自動更新系統并保持安全?

云服務器自動更新系統是保障安全、修補漏洞的重要措施。下面是常見 Linux 系統&#xff08;如 Ubuntu、Debian、CentOS&#xff09;和 Windows 服務器自動更新的做法和建議&#xff1a; 1. Linux 云服務器自動更新及安全維護 Ubuntu / Debian 系統 手動更新命令 sudo apt up…

fvm install 下載超時 過慢 fvm常用命令、flutter常用命令

Git 配置問題 確保 Git 使用的是 HTTPS&#xff0c;而不是 SSH。如果你有 .gitconfig&#xff0c;確保沒有配置奇怪的代理&#xff1a; git config --global --get http.proxy git config --global --get https.proxy如果有代理設置且不需要&#xff0c;取消代理&#xff1a;…

多語種OCR識別系統,引領文字識別新時代

在全球化與數字化深度融合的今天&#xff0c;語言障礙成為企業跨國協作、信息管理的一大挑戰。無論是跨國合同簽署、多語言檔案管理&#xff0c;還是跨境商務溝通&#xff0c;高效精準的文字識別技術已成為剛需。中安智能OCR多語種識別系統應運而生&#xff0c;憑借其強大的光學…

Pyenv 使用指南:多版本 Python 環境管理

目錄 Pyenv 是什么&#xff1f;安裝 Pyenv管理 Python 版本虛擬環境管理項目級 Python 版本控制高級技巧常見問題解決最佳實踐 Pyenv 是什么&#xff1f; Pyenv 是一個強大的 Python 版本管理工具&#xff0c;允許你&#xff1a; 在同一臺機器上安裝多個 Python 版本輕松切換…

Windows 11 家庭版 安裝Docker教程

Windows 家庭版需要通過腳本手動安裝 Hyper-V 一、前置檢查 1、查看系統 快捷鍵【winR】&#xff0c;輸入“control” 【控制面板】—>【系統和安全】—>【系統】 2、確認虛擬化 【任務管理器】—【性能】 二、安裝Hyper-V 1、創建并運行安裝腳本 在桌面新建一個 .…

leetcode:479. 最大回文數乘積(python3解法,數學相關算法題)

難度&#xff1a;簡單 給定一個整數 n &#xff0c;返回 可表示為兩個 n 位整數乘積的 最大回文整數 。因為答案可能非常大&#xff0c;所以返回它對 1337 取余 。 示例 1&#xff1a; 輸入&#xff1a;n 2 輸出&#xff1a;987 解釋&#xff1a;99 x 91 9009, 9009 % 1337 …

VR看房系統,新生代看房新體驗

VR看房系統的概念 虛擬現實&#xff08;VirtualReality,VR&#xff09;看房系統&#xff0c;是近年來隨著科技進步在房地產行業中興起的一種創新看房方式。看房系統利用先進的計算機技術模擬出一個三維環境&#xff0c;使用戶能夠身臨其境地瀏覽和體驗房源&#xff0c;無需親自…

棧與隊列:數據結構的有序律動

在數據結構的舞臺上&#xff0c;棧與隊列宛如兩位優雅的舞者&#xff0c;以獨特的節奏演繹著數據的進出規則。它們雖不像順序表與鏈表那般復雜多變&#xff0c;卻有著令人著迷的簡潔與實用&#xff0c;在眾多程序場景中發揮著不可或缺的作用。今天&#xff0c;就讓我們一同去探…

Flutte ListView 列表組件

目錄 1、垂直列表 1.1 實現用戶中心的垂直列表 2、垂直圖文列表 2.1 動態配置列表 2.2 for循環生成一個動態列表 2.3 ListView.builder配置列表 列表布局是我們項目開發中最常用的一種布局方式。Flutter中我們可以通過ListView來定義列表項&#xff0c;支持垂直和水平方向展示…

跟Gemini學做PPT-模板樣式的下載

好的&#xff0c;這里有一些推薦的網站&#xff0c;您可以在上面找到PPT目錄樣式和模板的靈感&#xff1a; SlideModel (slidemodel.com) 提供各種預先設計的目錄幻燈片模板。這些模板100%可編輯&#xff0c;可用于PowerPoint和Google Slides。您可以找到不同項目數量&#xff…