容易忽視的性能殺手:TableView刷新優(yōu)化特例

TableView優(yōu)化檢查清單一篇中,例出了TableView優(yōu)化常見的一些入手點(diǎn)檩赢,本篇將給出一個(gè)在特定效果下吕嘀,會(huì)影響TableView 刷新效率的一種情形及優(yōu)化方法,在你決定用復(fù)雜方法優(yōu)化TableView時(shí)贞瞒,提前排除這種可能偶房。

簡(jiǎn)單的文本也會(huì)導(dǎo)致低刷新率

本例中,cell將顯示3000個(gè)數(shù)字:


TableView效果
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"KeyCell"];

    cell.textLabel.text = [NSString stringWithFormat:@"%ld", indexPath.row];
    cell.textLabel.backgroundColor = [UIColor clearColor];
    cell.textLabel.layer.shadowOffset = CGSizeMake(0, 2);
    cell.textLabel.layer.shadowOpacity = 0.5;
    return cell;
}

看上去是很簡(jiǎn)單的cell军浆,下面用 Instruments 測(cè)一下FPS:

未優(yōu)化前的FPS

出人意料地低棕洋,平均沒有超過40FPS,是什么原因呢乒融?

離屏渲染

打開“離屏渲染”標(biāo)示:
離屏渲染檢查

可見掰盘,透明背景+陰影引發(fā)了離屏渲染,去掉后FPS恢復(fù)正常赞季,可是這樣又達(dá)不到需要的陰影效果愧捕,有什么辦法可以兩全其美呢?

陰影也有高刷新率

我們可以做如下設(shè)置:

cell.layer.shouldRasterize = YES;

當(dāng)shouldRasterize設(shè)成true時(shí)申钩,將渲染光柵化次绘,即將layer渲染成一個(gè)bitmap,并緩存起來撒遣,等下次使用時(shí)直接使用緩存邮偎,不再重新去渲染,減少了GPU的占用义黎。
由于bitmap是位圖钢猛,在屏幕上就會(huì)有些失真,會(huì)看到毛刺比較明顯:

開啟光柵化后導(dǎo)致失真

需要設(shè)置比例值:

cell.layer.rasterizationScale = [UIScreen mainScreen].scale;

這樣就可以即保證陰影的渲染效果轩缤,又保證了刷新率。

小提示

有些時(shí)候贩绕,發(fā)生問題的未必是復(fù)雜的數(shù)據(jù)火的,也有可能是系統(tǒng)機(jī)制的原因,因此先通過工具定位問題淑倾,再有針對(duì)性地進(jìn)行優(yōu)化馏鹤,記住:

提前優(yōu)化是萬惡之源娇哆。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末湃累,一起剝皮案震驚了整個(gè)濱河市勃救,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌治力,老刑警劉巖蒙秒,帶你破解...
    沈念sama閱讀 223,207評(píng)論 6 521
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異宵统,居然都是意外死亡晕讲,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,455評(píng)論 3 400
  • 文/潘曉璐 我一進(jìn)店門马澈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來瓢省,“玉大人,你說我怎么就攤上這事痊班∏诨椋” “怎么了?”我有些...
    開封第一講書人閱讀 170,031評(píng)論 0 366
  • 文/不壞的土叔 我叫張陵涤伐,是天一觀的道長(zhǎng)馒胆。 經(jīng)常有香客問我,道長(zhǎng)废亭,這世上最難降的妖魔是什么国章? 我笑而不...
    開封第一講書人閱讀 60,334評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮豆村,結(jié)果婚禮上液兽,老公的妹妹穿的比我還像新娘。我一直安慰自己掌动,他們只是感情好四啰,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,322評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著粗恢,像睡著了一般柑晒。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上眷射,一...
    開封第一講書人閱讀 52,895評(píng)論 1 314
  • 那天匙赞,我揣著相機(jī)與錄音,去河邊找鬼妖碉。 笑死涌庭,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的欧宜。 我是一名探鬼主播坐榆,決...
    沈念sama閱讀 41,300評(píng)論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼冗茸!你這毒婦竟也來了席镀?” 一聲冷哼從身側(cè)響起匹中,我...
    開封第一講書人閱讀 40,264評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎豪诲,沒想到半個(gè)月后顶捷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,784評(píng)論 1 321
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡跛溉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,870評(píng)論 3 343
  • 正文 我和宋清朗相戀三年焊切,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片芳室。...
    茶點(diǎn)故事閱讀 40,989評(píng)論 1 354
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡专肪,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出堪侯,到底是詐尸還是另有隱情嚎尤,我是刑警寧澤,帶...
    沈念sama閱讀 36,649評(píng)論 5 351
  • 正文 年R本政府宣布伍宦,位于F島的核電站芽死,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏次洼。R本人自食惡果不足惜关贵,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,331評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望卖毁。 院中可真熱鬧揖曾,春花似錦、人聲如沸亥啦。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,814評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)翔脱。三九已至奴拦,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間届吁,已是汗流浹背错妖。 一陣腳步聲響...
    開封第一講書人閱讀 33,940評(píng)論 1 275
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留疚沐,地道東北人暂氯。 一個(gè)月前我還...
    沈念sama閱讀 49,452評(píng)論 3 379
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像濒旦,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子再登,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,995評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容