偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

迭代器設(shè)計(jì)模式,幫你大幅提升Python性能

開(kāi)發(fā) 后端
今天給大家介紹的設(shè)計(jì)模式非常簡(jiǎn)單,叫做iterator,也就是 迭代器模式 。

 [[373430]]

今天給大家介紹的設(shè)計(jì)模式非常簡(jiǎn)單,叫做iterator,也就是 迭代器模式 。迭代器是Python語(yǔ)言當(dāng)中一個(gè)非常重要的內(nèi)容,借助迭代器我們可以很方便地實(shí)現(xiàn)很多復(fù)雜的功能。在深度學(xué)習(xí)當(dāng)中,數(shù)據(jù)的獲取往往也是通過(guò)迭代器實(shí)現(xiàn)的。因此這部分的內(nèi)容非常重要,推薦大家一定要掌握。

簡(jiǎn)單案例

在開(kāi)始介紹設(shè)計(jì)模式之前,我們先來(lái)看一個(gè)簡(jiǎn)單的需求。假設(shè)現(xiàn)在我們需要根據(jù)傳入的變量獲取每周的前幾天,比如說(shuō)我們傳入3返回的就是[Mon, Tue, Wed],我們傳入5返回[Mon, Tue, Wed, Thu, Fri]。這個(gè)需求大家應(yīng)該都能理解,非常非常簡(jiǎn)單。

如果用一個(gè)函數(shù)來(lái)實(shí)現(xiàn)的話(huà),就是這樣:

  1. def return_days(n): 
  2.     week = ['Mon''Tue''Wed''Thu''Fri''Sat''Sun'
  3.     return week[:n] 

你看三行代碼就實(shí)現(xiàn)了,在這個(gè)問(wèn)題場(chǎng)景當(dāng)中這樣寫(xiě)當(dāng)然是沒(méi)有問(wèn)題。但假如我們把題目稍微變一變,這里的week不是一個(gè)固定的數(shù)據(jù),而是從上游或者是某個(gè)文件當(dāng)中讀取的。這里的n也是一個(gè)很大的數(shù),我們把這個(gè)函數(shù)改寫(xiě)成這樣:

  1. def get_data(n): 
  2.     data = [] 
  3.     for i in range(n): 
  4.         data.append(get_from_upstream()) 
  5.     return data 

我們假設(shè)get_from_upstream這個(gè)函數(shù)當(dāng)中實(shí)現(xiàn)了獲取數(shù)據(jù)的具體邏輯,那么上面這一段函數(shù)有一個(gè)什么問(wèn)題?

有些同學(xué)會(huì)說(shuō)這沒(méi)有問(wèn)題啊,因?yàn)橄袷瞧渌Z(yǔ)言實(shí)現(xiàn)數(shù)據(jù)獲取的時(shí)候也都是這么干的。的確,像是Java等語(yǔ)言可能都是這么干的。但是其他語(yǔ)言這么干沒(méi)錯(cuò),不代表Python這么干也沒(méi)錯(cuò)。因?yàn)槲覀?nbsp;沒(méi)有把Python的能力發(fā)揮到最大 。

這里有兩個(gè)問(wèn)題,第一個(gè)問(wèn)題是 延遲 ,因?yàn)榍懊嬲f(shuō)了,n是一個(gè)很大的數(shù)。我們從上游獲取數(shù)據(jù),無(wú)論是通過(guò)網(wǎng)絡(luò)還是文件讀取,本質(zhì)上都是IO操作,IO操作的延遲是非常大的。那么我們把這n條數(shù)據(jù)全部搜集完可能需要很長(zhǎng)的時(shí)間,導(dǎo)致下游的漫長(zhǎng)等待。第二個(gè)問(wèn)題就是內(nèi)存,因?yàn)槲覀兇鎯?chǔ)了這n條數(shù)據(jù)一起返回的,如果n很大,對(duì)于內(nèi)存的開(kāi)銷(xiāo)壓力也很大,如果機(jī)器內(nèi)存不夠很有可能導(dǎo)致崩潰。

那怎么解決呢?

其實(shí)解決的方法很簡(jiǎn)單,如果對(duì)迭代器熟悉的話(huà),會(huì)發(fā)現(xiàn)迭代器針對(duì)的恰恰是這兩個(gè)問(wèn)題。我們把上面的邏輯改寫(xiě)成迭代器實(shí)現(xiàn)即可,這也就是iterator模式。

iterator模式

iterator模式嚴(yán)格說(shuō)起來(lái)其實(shí)只是迭代器的一種應(yīng)用,它非常巧妙地 將迭代器與匿名函數(shù)結(jié)合在一起 ,里面也沒(méi)有太多的門(mén)道可以說(shuō),我們把剛才的代碼改寫(xiě)一下,細(xì)節(jié)都在代碼當(dāng)中。

  1. def get_data(n): 
  2.     for i in range(n): 
  3.   yield get_from_upstream() 
  4.  
  5.  
  6. data_10 = lambda: get_data(10
  7. data_100 = lambda: get_data(100
  8.  
  9. # use 
  10. for d in data_10: 
  11.     print(d) 

很簡(jiǎn)單吧,但可能你要問(wèn)了,我們既然寫(xiě)出了get_data這個(gè)迭代器,那么我們使用的時(shí)候直接for d in get_data(10)這樣用不就好了,為什么中間要用匿名函數(shù)包一層呢?

道理也很簡(jiǎn)單,如果這個(gè)數(shù)據(jù)是我們自己使用,當(dāng)然是沒(méi)必要中間包一層的。但如果我們是傳給下游使用的話(huà),對(duì)于下游來(lái)說(shuō)它肯定是不希望考慮上游太多的細(xì)節(jié)的,越簡(jiǎn)單越好。所以我們直接丟一個(gè)包裝好的迭代器過(guò)去,下游直接call即可。否則的話(huà),下游還需要感知get_data這個(gè)函數(shù)傳入的參數(shù),顯然是不夠合理的。

責(zé)任編輯:張燕妮 來(lái)源: 博客園
相關(guān)推薦

2023-04-10 09:15:25

Vite 4.3SWC 插件

2023-11-09 08:46:24

2021-06-22 15:27:13

設(shè)計(jì)模式迭代器模式Java

2012-10-16 14:00:08

獵豹瀏覽器

2024-06-04 00:00:01

微軟EdgeReact

2020-11-06 09:01:46

迭代器模式

2023-11-26 09:04:10

Vue性能

2010-04-29 08:53:11

PHP迭代器模式

2024-04-29 18:55:16

緩存Spring性能

2024-08-19 00:05:25

2014-05-28 14:10:11

CrossApp

2024-12-11 07:59:02

2023-05-25 20:06:17

Linux游戲性能

2022-03-29 07:52:07

設(shè)計(jì)模式單例設(shè)計(jì)模式java

2025-04-28 10:16:35

VSCode插件開(kāi)發(fā)

2009-04-27 16:27:49

LinuxKernel 2.6.Intel

2009-12-10 09:23:13

ASP.NET開(kāi)發(fā)

2010-01-21 23:29:06

戴爾銀行東亞銀行

2023-06-12 00:36:28

迭代向量化Pandas

2022-11-08 15:11:17

GPU開(kāi)源
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)