精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

淺談iOS頁面流暢技巧

移動開發
如果在一個 VSync 時間內,CPU 或者 GPU 沒有完成內容提交,則那一幀就會被丟棄,等待下一次再顯示,而這時顯示屏會保留之前的內容不變,這就是卡頓的原因。

一、屏幕顯示圖像原理

淺談iOS頁面流暢技巧

首先明確兩個概念:水平同步信號、垂直同步信號。

CRT的電子槍按照上圖中的方式,從上到下一行行掃描掃描完成后顯示器就呈現一幀畫面,隨后電子槍回到初始位置繼續下一次的掃描。當電子槍切換到新的一行準備掃描時,顯示器會發送一個水平同步信號(Horizonal Synchronization),簡稱HSync;完成一幀畫面繪制后,電子槍會回到原位,顯示器會發送一個垂直同步信號(Vertical Synchronization),簡稱VSync。

CUP計算好顯示內容提交到GPU,GPU渲染完成后將渲染結果放入幀緩沖區,之后視頻控制器按照VSync 信號逐行讀取幀緩沖區中的數據,***經過各種數模轉換傳遞給顯示器顯示。

淺談iOS頁面流暢技巧

二、卡頓產生的原因

如果在一個 VSync 時間內,CPU 或者 GPU 沒有完成內容提交,則那一幀就會被丟棄,等待下一次再顯示,而這時顯示屏會保留之前的內容不變,這就是卡頓的原因。

三、CPU資源消耗的原因和解決方案

1.對象的創建

對象的創建會分配內存、調整屬性、甚至還有讀取文件的操作,比較消耗CPU資源。因此可以:

  • (1) 盡量用輕量的對象代替重量的對象,如CALayer比UIView輕量的多,在不需要響應觸摸事件時,用CALayer顯示更合適;
  • (2) 如果對象不涉及 UI 操作,盡量放到后臺線程去創建;
  • (3) 通過 storyboard 創建視圖對象時,其資源消耗會比直接通過代碼創建對象要大非常多,所以盡量避免使用;
  • (4) 盡量推遲對象創建的時間,并把對象的創建分散到多個任務中去;
  • (5) 如果對象可以復用,并且復用的代價比釋放、創建新對象要小,那么這類對象應當盡量放到一個緩存池里復用。

 

對象調整

對象的調整也是經常消耗CPU資源的地方。尤其是CALayer:

  • (1) CALayer 內部沒有屬性,當調用屬性方法時,它內部是通過運行時 resolveInstanceMethod 為對象臨時添加一個方法,并把對應屬性值保存到內部的一個 Dictionary 中,同時還會告知 delegate、創建動畫等等,非常消耗資源;
  • (2) UIView 關于顯示相關的屬性 (比如 frame/bouds/transform等)實際上都是CALayer 屬性映射出來的,所以對UIView 的這些屬性進行調整時,消耗的資源要遠大于一般的屬性,因此應該盡量減少類似的不必要的屬性的修改;
  • (3) 當視圖層次調整時,UIView、CALayer 之間會出現很多調用與通知,所以在優化性能時,應該盡量避免調整視圖層次、添加和移除視圖。

 

3.對象銷毀

當容器類持有大量對象時,其銷毀時的資源消耗就非常明顯。所以,盡量去后臺線程釋放對象。可以這么做:把對象捕獲到 block 中,然后扔到后臺隊列去隨便發送個消息以避免編譯警告,就可以讓對象在后臺線程銷毀了:

  1. NSArray *tmp = self.arr_data; 
  2. self.arr_data = nil; 
  3. dispatch_async(queue, ^{ 
  4.     [tmp class]; 
  5.  }); 

 

4.對象布局

在后臺線程提前計算好試圖布局、并對視圖的布局進行緩存。

不論通過何種技術對視圖進行布局,最終都會落到對 UIView.frame/bounds/center 等屬性的調整上

5.Autolayout

這是蘋果本身提倡的技術,在大部分情況下能很好的提升開發效率,但對于復雜視圖來說常會產生嚴重的性能問題。隨著視圖數量的增長,Autolayout 帶來的CPU消耗會呈指數級增長

6.文本計算

如果一個界面中包含大量的文本,文本的寬高計算會占用很大一部分資源,并且不可避免。

7.文本渲染

屏幕上能看到的所有的文本內容控件包括 UIWebView,在底層都是通過 CoreText 排版、繪制為 Bitmap 顯示的,并且該排版、繪制都是在主線程進行的。

顯示大量文本時,CPU 的壓力非常大,可以通過自定義文本控件,用TextKit 或***層的 CoreText 對文本異步繪制,盡管麻煩但優勢強大:

  • (1) CoreText 對象能直接獲取文本的寬高等信息,避免了多次計算(調整 UILabel 大小時算一遍、UILabel 繪制時內部再算一遍);
  • (2) CoreText 對象占用內存較小,可以緩存下來以備稍后多次渲染。

8.圖片解碼

用 UIImage 或者 CGImageSource 的方法創建圖片時,圖片數據并不會立刻解碼。圖片設置到UIImageView 或者 CALayer.contents 中,并且CALayer 被提到 GPU前,CGImage 中的數據才會得到解碼。

該步是發生在主線程,并且不可避免。如果想繞開這個機制,常見的方法是在后天線程先把圖片繪制到 CGBitmapContext中,然后從 Bitmap 直接創建圖片。目前常見的網絡圖片庫都自帶這個功能。

9.圖像的繪制

是指用那些以CG開頭的方法把圖像繪制到畫布中,然后從畫布創建圖片并顯示。常見的就是 [ UIView drawRect: ]。CoreGraphic 方法通常是線程安全的,所以圖像的繪制可以放到后臺線程運行。如下:(實際情況比這個復雜,但原理基本一致)

  1. - (void)display { 
  2.     dispatch_async(backgroundQueue, ^{ 
  3.         CGContextRef ctx = CGBitmapContextCreate(...); 
  4.         // draw in context... 
  5.         CGImageRef img = CGBitmapContextCreateImage(ctx); 
  6.         CFRelease(ctx); 
  7.         dispatch_async(mainQueue, ^{ 
  8.             layer.contents = img; 
  9.         }); 
  10.     }); 

四、GPU資源消耗原因和解決方案

GPU 能干的事情比較單一:接受提交的紋理(Texture)和頂點描述(三角形)、應用變換(transform)、混合并渲染,然后輸出到屏幕上。看到的內容通常主要是紋理(圖片)和形狀(三角模擬的矢量圖形)兩類。

1.紋理的渲染

所有的 Bitmap,包括圖片、文字、柵格化的內容,最終都要由內存提交到顯存,綁定為 GPU Texture。不論是提交到顯存的過程,還是 GPU 調整和渲染 Texture 的過程,都要消耗不少 GPU 資源。

當在短時間內顯示大量圖片時(如TableView),CPU占用率很低,GPU 占用非常高,界面會掉幀。

當圖片過大,超過 GPU 的***紋理尺寸時,圖片需要先由 CPU 進行預處理,這對 CPU 跟 GPU 都會帶來額外的消耗。

2.視圖的混合(Composing)

當多個視圖(或者 CALayer)重疊在一起顯示時,GPU 會首先把他們混合到一起。如果視圖結構過于復雜,混合的過程也會消耗很多的 GPU 資源。

所以應當盡量減少視圖數量和層次,并在不透明的視圖里標明 opaque 屬性以避免無用的Alpha 通道合成。

也可以把多個視圖預先渲染為一張圖片來顯示

3.圖形的生成

CALayer 的 border、圓角、陰影、遮罩(mask),CASharpLayer 的矢量圖形顯示,通常會觸發離屏渲染(offscreen rendering),而離屏渲染通常發生在 GPU 中。

當列表中出現大量圓角的 CALayer并且快速滑動時,GPU 資源可能幾近占滿,而 CPU 資源消耗很少,這時候界面仍能正常滑動但平均幀數降到很低。這時候可以嘗試開啟CALayer.shouldRaster 屬性,但這會離屏渲染操作轉嫁到 CPU上。

對于只需要圓角的某些場合,可以用一張已經繪制好的圓角圖片覆蓋到原視圖上來模擬出相同的視覺效果

最徹底的做法:把需要顯示的圖形在后臺線程繪制為圖片,避免使用圓角、陰影、遮罩等屬性。

責任編輯:未麗燕 來源: 簡書
相關推薦

2015-12-01 09:02:58

ios界面流暢

2013-04-24 15:56:40

2017-12-14 10:35:54

iOSAPPiPhone

2025-08-01 09:01:00

2017-07-21 14:00:00

iOSCrashMach異常

2017-07-25 12:40:42

iOSCrash僵尸對象

2010-01-06 09:19:45

2013-05-17 10:54:37

iOS開發iOS SDK調試技巧

2011-07-07 11:03:07

iOS MVC Objective-

2017-11-10 13:02:44

iOSUI代碼

2011-07-28 10:01:19

IOS 內存優化

2012-01-18 10:20:31

2009-07-01 18:08:18

JSP頁面跳轉

2011-05-10 11:16:29

模塊布線線纜

2011-07-27 15:11:02

2014-08-29 11:17:00

電梯布線

2017-05-24 10:58:28

linux系統技巧

2011-08-02 10:50:56

iOS開發 內存緩存

2011-07-28 17:20:55

2022-04-06 14:25:19

視頻跨頁面技術
點贊
收藏

51CTO技術棧公眾號

亚洲电影一级黄| 国产一区二区美女诱惑| 亚洲天堂免费视频| 在线观看免费av网址| 日本大片在线播放| 91蜜桃婷婷狠狠久久综合9色| 日本欧美一级片| 久久久久亚洲av片无码| 高潮久久久久久久久久久久久久 | 欧美www视频| 免费在线激情视频| 久久77777| 91久色porny| 国产日韩欧美综合| 国产免费观看av| 亚洲激情久久| 亚洲香蕉av在线一区二区三区| 捷克做爰xxxⅹ性视频| 电影一区二区三区| 一区二区欧美国产| 亚洲不卡1区| 香蕉视频黄在线观看| 精品影院一区二区久久久| 69视频在线免费观看| 久久精品日韩无码| 免费看成人哺乳视频网站| 91精品国产免费| 亚洲综合在线网站| 99爱在线视频| 亚洲精品精品亚洲| 一区二区三区久久网| 日本福利片高清在线观看| 国产久卡久卡久卡久卡视频精品| 国产精品成人va在线观看| 国产在线视频99| 7777久久香蕉成人影院| 国产一区二区三区直播精品电影| 偷偷色噜狠狠狠狠的777米奇| 91麻豆精品一二三区在线| 在线影院国内精品| 久久国产亚洲精品无码| 日韩精品卡一| 一区二区三区欧美日| 视频一区二区三| 男操女在线观看| 成人av电影在线| 国产精品乱码一区二区三区| 国产欧美日韩成人| 国产一区二区h| 成人在线观看视频网站| 91丨九色丨丰满| 日韩电影在线免费观看| 日本精品久久久| 国产中文字幕免费| 伊人久久综合| 国产69精品久久久久9| 国产精品国产三级国产传播| 97久久夜色精品国产| 在线播放精品一区二区三区 | 五月国产精品| 日韩精品一区二区三区第95| xxxxxx黄色| 老司机精品在线| 亚洲国产精品久久91精品| 免费不卡的av| 精品视频在线你懂得| 日韩成人xxxx| 国产色视频一区二区三区qq号| 青青草久久爱| 亚洲一区www| 国产一区二区三区四区在线| 91综合在线| 欧美成人免费在线观看| 欧美极品视频在线观看| 亚洲激情另类| 青青精品视频播放| 日本妇乱大交xxxxx| 久久99久国产精品黄毛片色诱| 国产精品自拍网| 国产v在线观看| 99久久精品费精品国产一区二区| 麻豆精品蜜桃一区二区三区| 欧美美女色图| ●精品国产综合乱码久久久久| 影音先锋男人的网站| 久久av色综合| 日本高清不卡aⅴ免费网站| www.夜夜爽| 国产精品久av福利在线观看| 亚洲色图第一页| 色婷婷在线视频观看| 欧美破处大片在线视频| 欧美中文字幕在线视频| 亚洲综合精品在线| 成年人国产精品| 色大师av一区二区三区| 影音先锋男人资源在线| 色综合欧美在线| 青娱乐精品在线| 在线日韩一区| 欧美成人免费网| 人人妻人人爽人人澡人人精品| 国产一区视频导航| 茄子视频成人在线观看| h片在线免费观看| 欧美日韩亚洲视频| 亚洲一区二区偷拍| 久久综合亚洲| 国模私拍视频一区| 亚洲一线在线观看| 91免费视频网| 日韩不卡视频一区二区| 日韩三区免费| 亚洲电影av在线| 91精品少妇一区二区三区蜜桃臀| 性xx色xx综合久久久xx| 亚洲在线一区二区| www.成人.com| 婷婷六月综合亚洲| 久久无码人妻一区二区三区| 国产亚洲一区| 国产91精品不卡视频| av一级黄色片| 国产精品福利一区二区| 毛片一区二区三区四区| 91久久偷偷做嫩草影院电| 中文字幕一精品亚洲无线一区| 日韩精品视频免费播放| 国产精品影视网| 一区二区三区四区| 在线日本欧美| 国产视频亚洲视频| 天天爽夜夜爽夜夜爽精品| 粉嫩aⅴ一区二区三区四区五区| 亚洲一区3d动漫同人无遮挡| 桃色一区二区| 日韩精品中文在线观看| 日韩经典在线观看| 成人动漫av在线| 国产内射老熟女aaaa| 9999精品| 久久天天躁狠狠躁夜夜躁| 一级片视频网站| 国产精品久久久久婷婷二区次| 免费在线观看的毛片| 亚洲电影男人天堂| 欧美专区中文字幕| 青青草免费在线| 日韩欧美在线免费| 五月天综合视频| 日韩av一二三| 天天久久人人| 在线观看欧美| 欧美成人久久久| 动漫av一区二区三区| 亚洲福利视频三区| 亚洲成人av免费在线观看| 久久国产成人| 日韩欧美三级电影| 欧美美女被草| 欧美美最猛性xxxxxx| www.久久综合| 天天做天天摸天天爽国产一区| 熟妇高潮精品一区二区三区| 亚洲一级在线| 色女人综合av| 国产成人久久精品一区二区三区| 欧美人成在线视频| 欧美一级做性受免费大片免费| 天天操天天干天天综合网| 鲁大师私人影院在线观看| 日韩在线a电影| 一区二区三区不卡在线| 我要色综合中文字幕| 国外成人在线直播| 国产在线一二三区| 欧美一区二区视频在线观看 | 调教视频免费在线观看| 91麻豆精品国产91久久久久| 欧美人与禽zozzo禽性配| caoporen国产精品视频| www日韩在线观看| 久久久久久影院| 狠狠色伊人亚洲综合网站色| 欧美xx视频| 欧美精品在线免费观看| 三级视频网站在线| 9191久久久久久久久久久| 中文字幕一区二区三区手机版 | 欧美tk丨vk视频| av网站中文字幕| 综合网在线视频| 欧美 日本 国产| 国产做a爰片久久毛片| av免费观看大全| 色婷婷色综合| 精品视频在线观看| 国产日韩中文在线中文字幕| 38少妇精品导航| 精产国品自在线www| 日韩激情视频在线| www.久久久久久| 欧美日韩一区二区在线视频| 久久久无码精品亚洲国产| 国产拍欧美日韩视频二区| 在线观看免费看片| 久久在线精品| 国产免费观看高清视频| 中文字幕人成人乱码| 日本不卡一区二区三区视频| 亚洲精品一区在线| 国产精品视频男人的天堂| 久草免费在线色站| 日韩一区视频在线| 久久久资源网| 亚洲国产精品久久91精品| 国产精品玖玖玖| 在线欧美日韩国产| 欧美精品亚洲精品日韩精品| 亚洲视频在线一区观看| 性猛交娇小69hd| 97精品久久久久中文字幕| 国产精品嫩草69影院| 韩国成人精品a∨在线观看| 看欧美ab黄色大片视频免费| 在线视频日韩| 一卡二卡三卡视频| 中文字幕亚洲综合久久五月天色无吗''| 欧美亚洲丝袜| 亲子伦视频一区二区三区| 岛国视频一区| 日韩免费精品| 亚洲一区二区三区xxx视频| 日本精品久久| 国产一区二区色| 九九九精品视频| 国产久一一精品| 国产一区二区三区四区五区3d| 热久久99这里有精品| 中文字幕资源网在线观看免费| 欧美精品videossex性护士| 91cn在线观看| 欧美成人精品在线观看| av在线免费网站| 欧美成人激情视频| 亚洲丝袜一区| 欧美高清videos高潮hd| 羞羞网站在线看| 九九久久国产精品| 五月婷婷视频在线观看| 欧美大片欧美激情性色a∨久久| av在线麻豆| 欧美激情亚洲国产| 多野结衣av一区| 欧美最猛性xxxxx(亚洲精品)| 欧美激情喷水| 国产精品亚洲网站| 在线视频成人| 成人羞羞视频免费| 欧美精品中文| 日本一区免费看| 欧美韩日高清| 日韩欧美一级在线| a91a精品视频在线观看| 男人天堂网视频| 青青青爽久久午夜综合久久午夜| 另类小说色综合| 国产一区二区成人久久免费影院| 国产xxx在线观看| 久久综合久久综合久久| 国产在线综合视频| 亚洲黄色av一区| 99热国产在线观看| 欧美性生活久久| www.好吊色| 亚洲人成五月天| 日本激情视频在线观看| 欧美日本高清一区| 一区二区电影免费观看| 成人天堂噜噜噜| 欧美三级午夜理伦三级小说| 日产中文字幕在线精品一区| 久久久久电影| 欧美精品一区免费| 久久国产剧场电影| 午夜免费福利影院| 欧美国产成人在线| 精品99久久久久成人网站免费 | 国产精品区在线观看| 欧美变态tickling挠脚心| 久久久久久青草| 欧美成人精品在线视频| 婷婷六月国产精品久久不卡| 亚洲综合社区网| 国产91精品对白在线播放| 永久免费看av| 日本午夜精品视频在线观看| 深夜做爰性大片蜜桃| 久久网站最新地址| 欧美日韩国产精品一区二区三区 | 国产人妖在线播放| 日韩激情第一页| 日本资源在线| 国产精品色婷婷视频| 久久精品色综合| 日韩 欧美 自拍| 日韩高清欧美激情| 最近中文字幕无免费| 亚洲精品免费电影| 中文字幕第315页| 日韩电影在线观看中文字幕| 免费高清在线观看| 日本三级韩国三级久久| 东京久久高清| 艳母动漫在线免费观看| 丝袜美腿亚洲色图| 捆绑凌虐一区二区三区| 亚洲人一二三区| 亚洲综合精品视频| 亚洲天堂av在线免费观看| bl在线肉h视频大尺度| 国产日韩精品视频| 精品国内自产拍在线观看视频 | 一区二区欧美日韩| 久久久久久色| 黄色正能量网站| 亚洲福利视频一区| 亚洲大尺度网站| 欧美尺度大的性做爰视频| 精品福利在线| 亚洲一区二区在| 久久电影网站中文字幕| 干b视频在线观看| 在线视频国内一区二区| 黄色在线网站| 国产精品久久久999| 国产亚洲欧美日韩在线观看一区二区| 中文字幕无码精品亚洲35| 成人午夜视频网站| 国产小视频在线观看免费| 日韩精品综合一本久道在线视频| 国产超级va在线视频| 91免费版网站入口| 亚洲成人三区| 中文字幕无人区二| 亚洲一区二区影院| 黄色aaa大片| 亚洲18私人小影院| 全球av集中精品导航福利| 国产h视频在线播放| 26uuu欧美日本| 欧美超碰在线观看| 在线视频亚洲欧美| av在线国产精品| 免费看日本黄色| av在线不卡观看免费观看| 日韩av在线电影| 亚洲人a成www在线影院| 亚洲成av在线| 三年中国中文在线观看免费播放| 国产麻豆成人传媒免费观看| 免费一级片在线观看| 亚洲白拍色综合图区| 女人让男人操自己视频在线观看 | 久蕉在线视频| 国产精品欧美日韩| 亚洲一区在线| 国产白袜脚足j棉袜在线观看| 福利精品视频在线| 91吃瓜网在线观看| 99porn视频在线| 亚洲一区二区免费看| 懂色av蜜桃av| 日韩欧美一二三| 欧美1级2级| 亚洲国产精品女人| 99re这里只有精品视频首页| 精品人妻一区二区三区潮喷在线| 啊v视频在线一区二区三区| 9l视频自拍蝌蚪9l视频成人| 国产成人无码一二三区视频| 国产精品乱子久久久久| 亚洲国产精品欧美久久| 日本高清久久天堂| 亚洲高清资源在线观看| 少妇精品一区二区| 欧美精品视频www在线观看| caoporn-草棚在线视频最| 亚洲乱码一区二区三区| 国产成人av电影在线播放| 中文字幕在线播| 精品少妇v888av| 国产精品欧美日韩一区| 少妇伦子伦精品无吗| 欧美专区日韩专区| 成人av影院在线观看| 伊人色综合影院| 久久精品夜夜夜夜久久| 免费激情视频网站| 国产免费成人av|