UITableViewCell的優化

Tip#1 學習怎么提升速度

1.打開你的項目并點擊Product>Profile

2.在那兒選擇Custom

3.找到添加按鈕并且添加工具:Allocations,Time,Profile,Leaks

4.觀察你的應用,以及他的表現。

Tip#2 避免阻塞主線程

在這個例子中你會看到第一個圖片相關的方法在數據下載并轉換成圖片對象時阻塞了主線程。你要盡量避免阻塞主線程,這對于collection中的交互對象尤為重要。網絡請求?保持他們在后臺運行(異步的)并且緩存傳回的響應。你肯定不想重復處理任何操作。想象你的cell在一段沉默時間內被繪制。你的cell應該只展示已經保存在你的設備上的數據。這會使你感覺更好的。

Tip#3 重用cells

如果你已經花了一些時間學習iOS,那么不好意思 。這條建議是給那些新接觸iOS的同學的。你應該使用dequeueReusableCellWithIdentifier 這個方法去獲取一個table或者collection上面的cell。如果你不是這樣做的,你就浪費了一段無意義的時間和數據。

Tip#4 緩存下載的圖片通常你會發現一個圖片類的app會在一個imageView上做下面這些事情:

1? 下載圖片(主要的內容圖片+用戶頭像圖片)

2? 更新時間戳

3? 展示評論

4? 計算動態的cell的高度

Tip#1 學習怎么提升速度

1.打開你的項目并點擊Product>Profile

2.在那兒選擇Custom

3.找到添加按鈕并且添加工具:Allocations,Time,Profile,Leaks

4.觀察你的應用,以及他的表現。

這肯定是你在這里讀到的最重要的一條建議了。如果你不緩存圖片你將會遇到很大的問題。

如果你重用本地的圖片那么請使用UIImage的方法imageNamed:。以JPG格式請求圖片將會節省時間和資源。如果你是從服務端獲取圖片那么你就可以獲取所需要的那些圖片( If you’re getting your image from a server you have the luxury of sending the exact image that’s needed.)。 PNG文件在內存中會占用很大一部分空間。如果你對此感覺好奇你可以在示例中將JPG換成PNG來下載一系列的PNG圖片。

使用 SDWebImage 或者 Heneke 來管理圖片。在提供的示例中我就是用的 Heneke,在那之前我沒有聽說過它也沒有聽說

Tip#5 使用富文本標簽代價是很昂貴的

費盡周折用富文本標簽,代價太昂貴了。盡可能地避免使用這個。問問你自己是否真的需要這個。如果是的話,盡可能的做緩存。

Tip#6 cell高度計算

如果你的table有復雜的動態高度那么你需要緩存計算的高度。考慮多久計算一次(尤其是對于collection views來說),你希望這些高度都是直接可用的。

Tip#7 NsDateFormatter 的痛苦

就像富文本,如果你頻繁地初始化,date formatter可以引起大量的內存消耗。比較理想的是你的web端為你提供可讀的文字(比起在最后的時間計算要容易很多)。如果沒有的話你可以創建一個NSDateFormatter的單例來使用。NSDateFormatter不是線程安全的,但是iOS7以及之后就不再是這樣了。多謝quellish提醒我這一點。

Tip#8 透明度

如果你能避免的話你創建的對象最好是不透明的(非透明的,你不能透過它看過去)。如果你有透明的圖片,系統必要要很努力地重繪這些圖片。實際上你可以在模擬器中通過點擊Debug>Clolor Blended Areas來看這些區域的問題。看到紅色的了么,那就意味著這些區域是透明的。當你在跟一個Collectionview打交道時這將是非常耗時。理想的,你想看到整個屏幕都是綠色的。對于你的設計來說那可能是不可行的,但是力求減少你看到的紅色的數量。在示例中你可以看到label延伸到了view的尾部,可以被清除掉。

Tip#9 不要過多使用Xib(如果可以的話使用storyboard)

如果要使用xib就要小心一點。當你加載一個Xib,整個的內容會被加載到內存中(圖片,隱藏的views)。但是這在storyboard中不會發生他只會實例化當前要用的東西。

有一些特殊的場景下使用xib很有意義。比如你可能會要使用一些第三方的框架而他們采用純代碼的方式來寫collection的UI部分。如果你想用xib來創建一個原型cell你可以用xib來做。只是要小心不要過載。

Tip#10 使用CoreGraphics

我很少需要這個,但是當你需要的時候你可以用。使用CoreGraphics并在一個view的drawRect的方法中寫你的UI代碼。

學習怎么使用Instruments(time profiler, allocations)

通過測試圖片緩存(關掉,打開,觀察)來檢查學習Instruments使用的情況。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,030評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,310評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,951評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,796評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,566評論 6 407
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,055評論 1 322
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,142評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,303評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,799評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,683評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,899評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,409評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,135評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,520評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,757評論 1 282
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,528評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,844評論 2 372

推薦閱讀更多精彩內容