精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

欧美成年黄网站色视频| 亚洲国产精品午夜在线观看| 欧美xxxx性| 亚洲嫩草精品久久| 成人国产一区二区| 国产尤物在线视频| 日韩电影一区| 精品久久久久久久人人人人传媒 | 亚洲一区免费网站| 国产精品黄色网| 欧美韩日一区| 亚洲第一黄色网| 日本久久久久久久久久久久| 亚洲区欧洲区| 国产日韩欧美高清在线| 99一区二区三区| 无码一区二区三区在线观看| 一区二区影视| 亚洲丝袜av一区| 精品国产aⅴ一区二区三区东京热| 欧美日韩国产v| 一二三区精品福利视频| 先锋影音欧美| 青青草视频在线免费观看| 寂寞少妇一区二区三区| 青青草国产精品一区二区| 精品一区在线观看视频| 九九热精品视频在线观看| 日韩天堂在线观看| 亚洲色图 在线视频| 黄频免费在线观看| 亚洲图片激情小说| 色综合视频二区偷拍在线| 欧美熟妇交换久久久久久分类| 另类综合日韩欧美亚洲| 日韩av手机在线观看| 国产一级做a爰片在线看免费| 久久精品播放| 亚洲视频在线免费看| 催眠调教后宫乱淫校园| 高清不卡一区| 欧美日本一区二区三区| 一级特黄性色生活片| 在线播放高清视频www| 亚洲午夜精品久久久久久久久| 中文字幕一区二区三区乱码 | 91亚洲男人天堂| av日韩免费电影| 国产区精品在线| 黑人巨大精品欧美黑白配亚洲| 国产精品国产三级国产aⅴ浪潮 | 丝袜在线观看| 亚洲精品中文字幕在线观看| 日本黄色播放器| 精品国产丝袜高跟鞋| 国产精品狼人久久影院观看方式| 色一情一乱一伦一区二区三区 | 久久久久北条麻妃免费看| 日韩av片在线免费观看| 日韩精品四区| 日日噜噜噜夜夜爽亚洲精品 | 熟妇人妻一区二区三区四区 | 国产视频亚洲| 2024亚洲男人天堂| av一级在线观看| 日韩电影在线免费| 国产日韩在线一区| www.97超碰| 成人网男人的天堂| 精品国产免费人成电影在线观...| 欧美熟妇乱码在线一区| 不卡av在线免费观看| 精品综合在线| 国产精品免费观看| 国产精品夫妻自拍| 加勒比海盗1在线观看免费国语版| 成人午夜在线影视| 一区二区不卡在线播放| 日韩精品xxxx| 成人黄色在线| 91精品国产综合久久久久久久久久 | 国产亚洲一区在线| 国产精品1234| 国产乱淫片视频| 国产91对白在线观看九色| 国产精品免费一区二区| 久蕉依人在线视频| 亚洲女与黑人做爰| 免费无码不卡视频在线观看| 国产精成人品2018| 日韩一区二区三区四区五区六区| 人妻互换一二三区激情视频| 免费一区二区| 九色精品美女在线| 亚洲靠逼com| 18禁免费无码无遮挡不卡网站| 中文另类视频| 精品久久人人做人人爰| 亚洲第一页av| 久久久久蜜桃| 日产精品久久久一区二区福利| 在线不卡免费视频| 北岛玲一区二区三区四区| 神马影院午夜我不卡影院| 亚洲wwwww| 91黄色免费版| 催眠调教后宫乱淫校园| 日韩精品午夜| 欧美专区第一页| 国产av无码专区亚洲av麻豆| 久久久天堂av| 很污的网站在线观看| 欧美午夜三级| 日韩av一区在线| 国产97免费视频| 日韩不卡在线观看日韩不卡视频| 国产精品二区二区三区| 性开放的欧美大片| 一本久道久久综合中文字幕| 天天爽夜夜爽视频| 清纯唯美亚洲综合一区| 18性欧美xxxⅹ性满足| 朝桐光av在线一区二区三区| 国产人妖乱国产精品人妖| 日韩伦理在线免费观看| 国产精品一区二区三区www| 亚洲欧美精品中文字幕在线| 国产乡下妇女做爰| 国产一区三区三区| 在线看无码的免费网站| 日本电影欧美片| 日韩电影中文 亚洲精品乱码| 久久久久亚洲AV成人| 蜜桃av一区二区在线观看| 蜜桃视频在线观看91| 97在线超碰| 日韩精品一区二区三区中文精品| 中文字幕美女视频| 麻豆精品一区二区三区| 日本在线免费观看一区| 在线观看欧美日韩电影| 亚洲国产天堂久久国产91| 免费网站观看www在线观| 精品一区二区三区在线播放视频| 性欧美videosex高清少妇| 欧美亚洲韩国| 亚洲天堂网站在线观看视频| 成人午夜视频在线播放| 久久综合久久综合久久综合| 少妇无码av无码专区在线观看 | 美女视频一区二区| 色噜噜狠狠一区二区三区| 日韩电影免费观| 亚洲乱码av中文一区二区| 女人十八岁毛片| av欧美精品.com| 无码人妻丰满熟妇区96| 欧美久久香蕉| 日本一区二区不卡| 国产一二三区在线| 欧美专区在线观看一区| 日韩精品久久久久久久的张开腿让| 日本va欧美va精品发布| 亚洲一区二区三区欧美| 国产精品一区免费在线 | 日本成人三级| 成人高清一区| 欧美另类交人妖| 殴美一级特黄aaaaaa| 午夜影视日本亚洲欧洲精品| 蜜桃精品成人影片| 日韩电影在线看| 男同互操gay射视频在线看| 一区二区三区视频免费视频观看网站| 欧美激情videos| 青青免费在线视频| 精品视频一区二区不卡| 国产a免费视频| 91香蕉视频在线| 污色网站在线观看| 欧美精品午夜| 欧美下载看逼逼| 国产精品免费精品自在线观看| 久久久久久久久久av| 午夜性色福利视频| 欧洲精品在线观看| 动漫性做爰视频| 久久影院午夜论| 91热视频在线观看| 一本色道久久| 中文字幕欧美日韩一区二区| 欧美理论电影在线精品| 国产精品女人久久久久久| 免费影视亚洲| 伊人久久五月天| 亚洲AV无码成人片在线观看| 色婷婷综合五月| 欧美日韩中文字幕在线观看| 91在线视频网址| 国产精品久久久久久久av福利| 国产日本精品| 国产又粗又大又爽的视频| 外国成人在线视频| 91久久精品www人人做人人爽| 日韩大片欧美大片| 久久久久久久一区二区| 丁香在线视频| 欧美精品一区二区在线播放| 最近中文字幕免费观看| 亚洲成人av资源| 蜜桃av.com| 久久久久国产一区二区三区四区| 亚洲av毛片在线观看| 欧美亚洲自偷自偷| 丰满少妇大力进入| 久久久久蜜桃| 天天好比中文综合网| 天堂俺去俺来也www久久婷婷| 91人人爽人人爽人人精88v| 成人线上视频| 久久久免费在线观看| 精品美女在线观看视频在线观看| 亚洲人精品午夜在线观看| 懂色av蜜臀av粉嫩av分享吧| 在线成人av影院| 中文字幕一区二区久久人妻| 欧美视频在线观看免费| 久久综合激情网| 亚洲人吸女人奶水| 国产在线免费看| 欧美高清在线视频| 国产aⅴ激情无码久久久无码| 成人黄色在线看| 日本50路肥熟bbw| 国精品**一区二区三区在线蜜桃| 中文久久久久久| 久久久久久久高潮| 国产超级av在线| 野花国产精品入口| 国产精品入口芒果| 欧美视频成人| 奇米777四色影视在线看| 91精品国产乱码久久久久久| 在线免费观看成人网| 日韩欧美自拍| 在线视频不卡一区二区| 精品色999| 亚洲国产一区二区三区在线播| 少妇精品久久久一区二区| 欧美男人的天堂| 美女精品一区最新中文字幕一区二区三区 | 99国产精品一区| 少妇精品一区二区| 久久综合久久综合久久综合| 成人性生交大免费看| 久久久久久99精品| 尤物视频最新网址| 国产精品视频一二| 国产又黄又粗又猛又爽的| 国产精品国产三级国产有无不卡 | 一二三级黄色片| 国产黄色91视频| 大桥未久恸哭の女教师| 99久久精品国产导航| 国产精品815.cc红桃| 欧美高清在线精品一区| 精品国产视频在线观看| 亚洲激情图片小说视频| 日韩欧美不卡视频| 一本到一区二区三区| 中文字幕资源网| 3d成人h动漫网站入口| 超碰在线观看99| 精品视频—区二区三区免费| yw视频在线观看| 欧美超级乱淫片喷水| 美女的胸无遮挡在线观看| 日本91av在线播放| 国产精品天堂蜜av在线播放 | 日韩中文字幕免费观看| 亚洲欧洲日本专区| 韩国av网站在线| 久久免费视频网站| 色豆豆成人网| 91亚洲精品在线| 亚洲警察之高压线| 欧美性视频在线播放| 影音国产精品| 欧美日韩在线免费播放| 国产一区二区三区免费播放| 大尺度做爰床戏呻吟舒畅| 亚洲国产精品黑人久久久| 欧美色图一区二区| 91国内精品野花午夜精品| jizz中国少妇| 国产午夜精品免费一区二区三区| 岛国成人毛片| 日本久久久久久久久| 国产一区二区av在线| 日本不卡一区二区三区视频| 好看的亚洲午夜视频在线| 日本爱爱免费视频| 成人免费高清在线| 欧美肥妇bbwbbw| 欧美日韩一区二区免费视频| 国产精品久久久久精| 国产视频综合在线| 青青青国内视频在线观看软件| 国产精品99免视看9| 岛国精品一区| 日本黄色播放器| 日韩成人午夜精品| 韩国无码一区二区三区精品| 一区二区三区蜜桃| 96日本xxxxxⅹxxx17| 国产视频精品久久久| 午夜影院免费在线| 国产综合久久久久久| 精品国产91久久久久久浪潮蜜月| 欧美视频免费看欧美视频| 国产在线日韩欧美| 欧美激情视频二区| 欧美性xxxx极品hd欧美风情| 免费观看黄一级视频| 超碰97人人做人人爱少妇| 日本免费成人| 亚洲国产精品一区二区第四页av| 亚洲影视综合| 好吊色视频一区二区三区| 亚洲一区中文日韩| www.com欧美| 欧美成年人视频网站欧美| 巨大黑人极品videos精品| 日韩高清国产精品| 美女日韩在线中文字幕| 国产国语性生话播放| 婷婷开心久久网| 欧美一区二区三区黄片| 久久久久久97| 九九热hot精品视频在线播放| 欧美激情亚洲天堂| 国产精品一区在线观看你懂的| 亚洲一区电影在线观看| 欧美日韩精品一区二区三区四区| 国产黄色免费在线观看| 国产精品999999| 成人亚洲一区| 日韩一区二区三区久久| 最新久久zyz资源站| 国产精品爽爽久久| 久久国产精品久久精品| 精品国产一区二| 亚洲啊啊啊啊啊| 国产不卡在线视频| 日韩精品久久久久久久| 亚洲经典中文字幕| 亚洲人成午夜免电影费观看| 热re99久久精品国产99热| 日韩中文字幕亚洲一区二区va在线| 三上悠亚影音先锋| 欧美亚洲图片小说| 精品孕妇一区二区三区| 5566av亚洲| 在线国产欧美| 91久久免费视频| 91黄色免费看| 成人在线直播| 九色综合日本| 日本成人在线电影网| 永久av免费网站| 精品国产青草久久久久福利| 中文字幕人成乱码在线观看 | 伊人青青综合网| 日本50路肥熟bbw| 日本韩国精品一区二区在线观看| sese一区| 福利视频久久| 久久都是精品| 成人在线观看免费完整| 精品成人在线观看| 免费观看成人性生生活片| 福利网在线观看| av动漫一区二区| 中文字幕一区二区人妻痴汉电车| 超薄丝袜一区二区| 曰本一区二区三区视频| 亚洲欧美日韩网站| 欧美视频在线观看免费| 国产在线观看91| 国产在线观看一区| 久久精品免费看| 国产精品一区二区6| 色噜噜久久综合伊人一本| 成人h动漫精品一区二区器材| 亚洲人成无码www久久久| 亚洲免费av在线| 欧美在线观看在线观看| 91国产在线播放| 日韩不卡免费视频| 亚洲激情视频一区|