亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS編程學習中關于throttle的那些事

2019-10-21 18:42:59
字體:
來源:轉載
供稿:網友

前言

不知道大家對throttle這個單詞是否看著眼熟,還是說對這個計算機基礎概念有很清晰的了解了。今天就來聊聊和throttle相關的一些技術場景。

定義

我經常有一種感覺,對于英語這門語言的語感,會影響我們對于一些關鍵技術概念的理解。有時候在學習新技術知識的時候,我會先花一些時間去了解術語英文單詞的各種語義,在形成強烈清晰的語感之后,再去深入具體的技術語境。throttle也算是個生僻的單詞,至少在口語中畢竟少用到,先來看看詞義:

a device controlling the flow of fuel or power to an engine.

中文翻譯是節流器,一種控制流量的設備。對應到我們計算機世界,可以理解成,一種控制數據或者事件流量大小的機制。這么說可能還是有些抽象,再來看看一些具體的技術場景加深理解。

場景一:GCD Background Queue

話說GCD幾乎是iOS面試的必問題,也是個送分題:)。

我一般會機械式的先問:GCD有哪幾種Queue?回答:串行Queue和并行Queue。

我繼續問:Global Queue有哪幾種優先級?回答:有幾種吧,大概記得Default,Low,High吧。

我雙眉一挑,進一步試探:不知道少俠有沒有研究過DISPATCH_QUEUE_PRIORITY_BACKGROUND作何用?問完立即豎起耳朵,殷殷期盼縈繞于心的關鍵字。如果能聽到「I/O Throttle 呀!」,我會瞬間覺得面試氣氛被點亮了。

當然啦,答不出I/O Throttle并不能說明技術不扎實,但能答出來,至少表明對待技術是有好奇心的,加分!

官方文檔如是說:

Items dispatched to the queue run at background priority; the queue is scheduled for execution after all high priority queues have been scheduled and the system runs items on a thread whose priority is set for background status. Such a thread has the lowest priority and any disk I/O is throttled to minimize the impact on the system.

那Disk I/O Throttle做什么用呢?按照上面這段描述,Disk I/O會impact system performance。

理解Disk I/O的影響需要補充一些大學課本上的知識。一次磁盤讀寫操作涉及到的硬件資源主要有兩個,CPU和磁盤。任務本身由CPU觸發和調度,讀操作發生時,CPU告知Disk去獲取某個地址的數據,此時由于Disk的讀操作存在尋址延遲,CPU是處于I/O wait狀態,一直維持到Disk返回數據為止。處于I/O wait狀態的CPU,此時并不能把這部分等待的時間用來處理其他任務,也就是說這一段等待的CPU時間被“浪費”了。而CPU是公共的系統資源,這部分資源的損耗自然會對系統的整體表現產生負面影響。即使Global Queue使用的是子線程,也會造成CPU資源的消耗。

如果把任務的Priority調整為DISPATCH_QUEUE_PRIORITY_BACKGROUND,那么這些任務中的I/O操作就被被控制,雖然具體的控制策略并沒有官方文檔描述(一種可能的策略是并發的Disk I/O變為串行的),但我們能確認的是,部分I/O操作的啟動時間很有可能被適當延遲,把更多的CPU資源騰出來處理其他任務(比如說一些系統資源的調度任務),這樣可以讓我們的系統更加穩定高效。簡而言之,對于重度磁盤I/O依賴的后臺任務,如果對實時性要求不高,放到DISPATCH_QUEUE_PRIORITY_BACKGROUND Queue中是個好習慣,對系統更友好。

實際上I/O Throttle還分為好幾種,有Disk I/O Throttle,Memory I/O Throttle,和Network I/O Throttle。語義類似只不過場景不同,繼續往下看。

場景二:ASIHttpRequest Network Throttle

早幾年讀ASIHttpRequest源碼的時候,讀到過一段有意思的代碼:

- (void)handleNetworkEvent:(CFStreamEventType)type{//... [self performThrottling];//...}

在AFNetworking中也有類似的代碼:

/** Throttles request bandwidth by limiting the packet size and adding a delay for each chunk read from the upload stream.  When uploading over a 3G or EDGE connection, requests may fail with "request body stream exhausted". Setting a maximum packet size and delay according to the recommended values (`kAFUploadStream3GSuggestedPacketSize` and `kAFUploadStream3GSuggestedDelay`) lowers the risk of the input stream exceeding its allocated bandwidth. Unfortunately, there is no definite way to distinguish between a 3G, EDGE, or LTE connection over `NSURLConnection`. As such, it is not recommended that you throttle bandwidth based solely on network reachability. Instead, you should consider checking for the "request body stream exhausted" in a failure block, and then retrying the request with throttled bandwidth.  @param numberOfBytes Maximum packet size, in number of bytes. The default packet size for an input stream is 16kb. @param delay Duration of delay each time a packet is read. By default, no delay is set. */- (void)throttleBandwidthWithPacketSize:(NSUInteger)numberOfBytes         delay:(NSTimeInterval)delay;

原諒我貼了一大段注釋,這段英文描述對于加深我們對于一些網絡行為的理解很有幫助。

這些知名的第三方網絡框架都有對Newtork Throttle的支持,你可能會好奇,我們為什么要對自己發出的網絡請求做流量控制,難道不應該盡可能最大限度的利用帶寬嗎?

此處需要科普一點TCP協議相關的知識。我們通過HTTP請求發送數據的時候,實際上數據是以Packet的形式存在于一個Send Buffer中的,應用層平時感知不到這個Buffer的存在。TCP提供可靠的傳輸,在弱網環境下,一個Packet一次傳輸失敗的概率會升高,即使一次失敗,TCP并不會馬上認為請求失敗了,而是會繼續重試一段時間,同時TCP還保證Packet的有序傳輸,意味著前面的Packet如果不被ack,后面的Packet就會繼續等待,如果我們一次往Send Buffer中寫入大量的數據,那么在弱網環境下,排在后面的Packet失敗的概率會變高,也就意味著我們HTTP請求失敗的幾率會變大,類似這樣:

ios,throttle

大部分時候在應用層寫代碼的時候,估計不少同學都意識不到Newtork Throttle這種機制的存在,在弱網環境下(丟包率高,帶寬低,延遲高)一些HTTP請求(比如上傳圖片或者日志文件)失敗率會激增,有些朋友會覺得這個我們也沒辦法,畢竟網絡辣么差。其實,作為有追求的工程師,我們可以多做一點點,而且弱網下請求的成功率其實是個很值得深入研究的方向。針對弱網場景,我們可以啟用Newtork Throttle機制,減小我們一次往Send Buffer中寫入的數據量,或者延遲某些請求的發送時間,這樣所有的請求在弱網環境下,都能「耐心一點,多等一會」,請求成功率自然也就適當提高啦。

那么,再看AFNetworking中的這個函數,是不是更能理解了呢?

- (void)throttleBandwidthWithPacketSize:(NSUInteger)numberOfBytes         delay:(NSTimeInterval)delay;

Network Throttle體現了一句至理名言「慢即是快」。

場景三:Event Frequency Control

不知道大家在寫UI的時候,有沒有遇到過用戶快速連續點擊UIButton,產生多次Touch事件回調的場景。以前機器還沒那么快的時候,我在用一些App的時候,時不時會遇到偶爾卡頓,多次點擊一個Button,重復Push同一個Controller。有些工程師會在Button的點擊事件里記錄一個timestamp,然后判斷每次點擊的時間間隔,間隔過短就忽略,這也不失為一種解決辦法。

再后來學習RxSwift的時候,看到:

button.rx_tap .throttle(0.5, MainScheduler.instance) .subscribeNext { _ in   print("Hello World") } .addDisposableTo(disposeBag)

終于有了優雅的書寫方式。發現沒有,throttle又出現了,這里throttle控制的是什么呢?不是disk讀寫,也不是network buffer,而是事件,把事件本身抽象成了一種Data,控制這種數據的流量或者產生頻率,就解決了上面我們所說重復點擊按鈕的問題,so easy。

總結

當然還會有更多的場景,throttle其實是個基礎的計算機知識。理解throttle相關的技術概念,需要在不同場景下去抽象出一個flow被節流的畫面。現在,如果讓你來解釋一些具體的技術場景下,throttle是怎么回事,是不是可以信手拈來了:)

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
69影院欧美专区视频| 国产成人精品在线| 久久精品国产亚洲一区二区| 在线日韩第一页| 亚洲人成网站999久久久综合| 91在线视频免费| 国产精品嫩草影院一区二区| 91a在线视频| 国产精品一区电影| 欧美福利在线观看| 久久精品成人动漫| 在线观看欧美视频| 91在线无精精品一区二区| 亚洲欧美中文日韩v在线观看| 久久夜色精品国产亚洲aⅴ| 欧美限制级电影在线观看| 欧美整片在线观看| 亚洲国产成人精品久久| 久久在线免费视频| 日韩av在线一区二区| 日韩欧美精品网址| 欧美日韩中文字幕在线视频| 亚洲第一天堂无码专区| 国产91精品青草社区| 日韩在线视频观看正片免费网站| 欧美在线影院在线视频| 国产精品大陆在线观看| 午夜精品久久久久久久99热| 欧美精品中文字幕一区| 91禁国产网站| 日韩成人av网址| www.午夜精品| 久久精视频免费在线久久完整在线看| 久久久免费观看| 国产精品99久久久久久久久久久久| 亚洲精选中文字幕| 亚洲欧美日韩另类| 亚洲性视频网站| 久久久精品欧美| 国产丝袜高跟一区| 日韩中文字幕欧美| 浅井舞香一区二区| 亚洲男女自偷自拍图片另类| 日韩欧美在线中文字幕| 久久久久久久久久久av| 91久久精品日日躁夜夜躁国产| 国产精品夜间视频香蕉| www.日韩系列| 国产一区二区三区欧美| 欧美精品精品精品精品免费| 亚洲人午夜精品免费| 国产成人精品免费视频| 最近2019中文免费高清视频观看www99| 日韩欧美极品在线观看| 国产日韩欧美影视| 日韩欧美国产一区二区| 亚洲精美色品网站| 热久久免费国产视频| 91麻豆国产精品| 日本伊人精品一区二区三区介绍| 97婷婷大伊香蕉精品视频| 日韩精品www| 国产一区私人高清影院| 亚洲男人的天堂在线播放| 亚洲三级黄色在线观看| 热99在线视频| 亚洲视频网站在线观看| 亚洲免费伊人电影在线观看av| 97精品久久久中文字幕免费| 亚洲夜晚福利在线观看| 国语自产精品视频在线看抢先版图片| 亚洲欧美视频在线| 日韩av一区二区在线观看| 国产人妖伪娘一区91| 在线播放国产一区二区三区| 欧美日韩久久久久| 亚洲人成电影在线| 成人黄色免费网站在线观看| 欧美老妇交乱视频| 日韩欧美aⅴ综合网站发布| 91色视频在线观看| 亚洲欧洲黄色网| 九色精品免费永久在线| 国产视频在线观看一区二区| 久久久久久久亚洲精品| 日韩电影免费在线观看中文字幕| 欧美资源在线观看| 中文字幕日韩有码| 亚洲第一网站免费视频| 国产在线精品一区免费香蕉| 国产精品免费久久久| 久久久噜噜噜久久久| 久久精品成人欧美大片古装| 91精品免费久久久久久久久| 亚洲欧美日韩在线高清直播| 欧美伦理91i| 亚洲国产精品嫩草影院久久| 国产精品v片在线观看不卡| 欧美一区二区大胆人体摄影专业网站| 国内精品久久久久久影视8| 日韩欧美高清在线视频| 夜夜躁日日躁狠狠久久88av| 亚洲欧洲在线观看| 亚洲天堂男人的天堂| 中文字幕精品视频| 海角国产乱辈乱精品视频| 97婷婷涩涩精品一区| 中文亚洲视频在线| 菠萝蜜影院一区二区免费| 91高潮在线观看| 亚洲美女福利视频网站| 国外成人在线视频| 欧美一级在线亚洲天堂| 欧美巨大黑人极品精男| 97久久久免费福利网址| 日韩免费在线看| 亚洲成人黄色在线| 久久激情五月丁香伊人| 亚洲国产精品视频在线观看| 久久综合色88| 91视频国产一区| 红桃视频成人在线观看| 欧美性猛xxx| 欧美与黑人午夜性猛交久久久| 91精品国产色综合久久不卡98口| 欧美男插女视频| 国语自产偷拍精品视频偷| 懂色av中文一区二区三区天美| 黄色成人在线播放| 国产精品一区二区久久久| 日韩成人在线网站| 欧美精品日韩www.p站| 欧美一区深夜视频| 久久久久中文字幕2018| 久久久久女教师免费一区| 7m第一福利500精品视频| 91av视频在线| 性欧美在线看片a免费观看| 欧美电影在线免费观看网站| 91精品久久久久久| 91美女片黄在线观看游戏| 亚洲成人动漫在线播放| 国产精品入口日韩视频大尺度| 欧美人成在线视频| 日韩福利伦理影院免费| 亚洲爱爱爱爱爱| 国产美女久久久| 国产丝袜一区二区| 欧美性开放视频| 久久精品国产久精国产一老狼| 深夜福利亚洲导航| 精品视频在线播放色网色视频| 国产69精品久久久久9| 91久久久久久久| 国产精品xxx视频| 国产一区二区三区日韩欧美| 国产高清视频一区三区| 国产亚洲一区二区在线| 国产精品视频精品| 欧美日韩亚洲高清| 中文字幕欧美精品在线| 日本高清视频精品| 日韩成人av网| 中国china体内裑精亚洲片|