15. UITableview的優(yōu)化方法

UITableview的優(yōu)化方法(緩存高度,異步繪制鸣皂,減少層級(jí)瞪讼,hide,避免離屏渲染)
  • 1 緩存高度
    提前計(jì)算好 cell 的高度和布局
    iOS8后蛛壳,會(huì)邊滑動(dòng)邊調(diào)用heightForRowAtIndexPath:這個(gè)方法; 如果把計(jì)算cell高度的方法寫在這兒, 不僅每次都會(huì)調(diào)用計(jì)算方法, 而且重復(fù)滑動(dòng)的話, 還會(huì)再次計(jì)算; 所以我們一般在網(wǎng)絡(luò)請(qǐng)求結(jié)束后杏瞻,更新界面之前就把每個(gè) cell 的高度算好所刀,緩存到相對(duì)應(yīng)的 model 中。

  • 2 異步繪制
    在Cell上添加系統(tǒng)控件的時(shí)候捞挥,實(shí)質(zhì)上系統(tǒng)都需要調(diào)用底層的接口進(jìn)行繪制浮创,當(dāng)我們大量添加控件時(shí),對(duì)資源的開銷也會(huì)很大砌函,所以我們可以索性直接繪制斩披,提高效率

  • 3 減少層級(jí)
    減少SubViews的數(shù)量, 在滑動(dòng)的列表上,多層次的view會(huì)導(dǎo)致幀數(shù)的下降讹俊。
    例如: 繪制 cell 不建議使用 UIView垦沉,建議使用 CALayer。
    從形式來說:UIView 的繪制是建立在 CoreGraphic 上的劣像,使用的是 CPU乡话。CALayer 使用的是 Core Animation,CPU耳奕,GPU 通吃绑青,由系統(tǒng)決定使用哪個(gè)。View的繪制使用的是自下向上的一層一層的繪制屋群,然后渲染闸婴。Layer處理的是 Texure,利用 GPU 的 Texture Cache 和獨(dú)立的浮點(diǎn)數(shù)計(jì)算單元加速 紋理 的處理芍躏。

  • 4.hide顯示
    盡量少用addView給Cell動(dòng)態(tài)添加View邪乍,可以初始化時(shí)就添加,然后通過hide來控制是否顯示

  • 5.避免離屏渲染:少用圓角对竣,可用貝塞爾曲線畫

  • 6.正確地使用UITableViewCell的重用機(jī)制:多種類型的cell庇楞,能不復(fù)用就不復(fù)用。

  • 7.避免阻塞主線程:子線程計(jì)算復(fù)雜的數(shù)學(xué)問題

    1. 按需加載:用懶加載
  • 9.盡可能重用開銷比較大的對(duì)象 比如:NSDateFormatter

  • 10 盡量減少計(jì)算的復(fù)雜度

  • 11.用輕量級(jí)的對(duì)象
    UIView是 CALayer 的代理否纬,layer本身并不能響應(yīng)事件吕晌,因?yàn)閘ayer是直接繼承自NSObject,不具備處理事件的能力临燃。而 UIView 是繼承了UIResponder 的睛驳,
    當(dāng)只是展示時(shí)用 layer 代替UIView

技巧

可以通過模擬器中debug模式查看圖層

  • Color Blended Layers 綠?色越多,代表混合的情況越少膜廊,紅?色越多App UI急需改進(jìn).
  • Slow Animations 該功能可以降低app中動(dòng)畫的運(yùn)?行行速度乏沸,適合調(diào)試包含復(fù)雜動(dòng)畫的應(yīng)?用程序
  • Color Copied Images:該選項(xiàng)可以給繪制時(shí)被Core Animation復(fù)制的圖?片添加藍(lán)綠?色疊加層。
  • Color Misaligned Images:如果圖?片邊界沒有與?目標(biāo)像素完美對(duì)?齊爪瓜,該功能可為圖?片疊加上?一層品紅?色蹬跃。如果圖?片使?用確定的?比例例?大?小繪制,那么該功能會(huì) 為圖?片添加?一層?黃?色疊加铆铆。
  • Color Off Screen Rendered:.該選項(xiàng)為離屏渲染內(nèi)容添加?一個(gè)?黃?色的疊加層蝶缀。
    --初稿

持續(xù)更新中......

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末辆苔,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子扼劈,更是在濱河造成了極大的恐慌,老刑警劉巖菲驴,帶你破解...
    沈念sama閱讀 217,657評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件荐吵,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡赊瞬,警方通過查閱死者的電腦和手機(jī)先煎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來巧涧,“玉大人薯蝎,你說我怎么就攤上這事“” “怎么了占锯?”我有些...
    開封第一講書人閱讀 164,057評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)缩筛。 經(jīng)常有香客問我消略,道長(zhǎng),這世上最難降的妖魔是什么瞎抛? 我笑而不...
    開封第一講書人閱讀 58,509評(píng)論 1 293
  • 正文 為了忘掉前任艺演,我火速辦了婚禮,結(jié)果婚禮上桐臊,老公的妹妹穿的比我還像新娘胎撤。我一直安慰自己,他們只是感情好断凶,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,562評(píng)論 6 392
  • 文/花漫 我一把揭開白布伤提。 她就那樣靜靜地躺著,像睡著了一般懒浮。 火紅的嫁衣襯著肌膚如雪飘弧。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,443評(píng)論 1 302
  • 那天砚著,我揣著相機(jī)與錄音次伶,去河邊找鬼。 笑死稽穆,一個(gè)胖子當(dāng)著我的面吹牛冠王,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播舌镶,決...
    沈念sama閱讀 40,251評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼柱彻,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼豪娜!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起哟楷,我...
    開封第一講書人閱讀 39,129評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤瘤载,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后卖擅,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鸣奔,經(jīng)...
    沈念sama閱讀 45,561評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,779評(píng)論 3 335
  • 正文 我和宋清朗相戀三年惩阶,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了挎狸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,902評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡断楷,死狀恐怖锨匆,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情冬筒,我是刑警寧澤恐锣,帶...
    沈念sama閱讀 35,621評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站账千,受9級(jí)特大地震影響侥蒙,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜匀奏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,220評(píng)論 3 328
  • 文/蒙蒙 一鞭衩、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧娃善,春花似錦论衍、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至瘫寝,卻和暖如春蜒蕾,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背焕阿。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工咪啡, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人暮屡。 一個(gè)月前我還...
    沈念sama閱讀 48,025評(píng)論 2 370
  • 正文 我出身青樓撤摸,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子准夷,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,843評(píng)論 2 354