真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

性能優(yōu)化策略

性能問題的處理流程

  • 發(fā)現(xiàn)/重現(xiàn)問題

    創(chuàng)新互聯(lián)主營米脂網(wǎng)站建設的網(wǎng)絡公司,主營網(wǎng)站建設方案,App定制開發(fā),米脂h5成都微信小程序搭建,米脂網(wǎng)站營銷推廣歡迎米脂等地區(qū)企業(yè)咨詢

  • 利用工具剖析

  • 形成假設

  • 改進代碼和設計

性能優(yōu)化策略

在以上的四個步驟中循環(huán)反復,直到問題解決。

Profile!不要猜!

性能優(yōu)化的主要策略:

  • 不要做無用功:不要在啟動時花幾百ms來做logging,不要為同樣的數(shù)據(jù)做多次查詢

  • 試圖重用:對于創(chuàng)建過程昂貴的對象,要重用而不是重新創(chuàng)建

    • Table View的cell

    • Date/Number的formatter

    • 正則表達式

    • SQLite語句

  • 使用更快的方式設計、編程:選擇正確的集合對象和算法來進行編程、選擇適合的數(shù)據(jù)存儲格式(plist、SQLite)、優(yōu)化SQLite查詢語句

  • 事先做優(yōu)化

    • 對于昂貴的計算,要進行事先計算。iCal中的重復事件,是預先計算出來的,并保存到數(shù)據(jù)庫中。

    • 事先計算并緩存一些對象,可能會占用大量的內(nèi)存。注意不要將這些對象聲明為static并常駐內(nèi)存。

  • 事后做優(yōu)化:異步加載、懶加載

  • 為伸縮性而做優(yōu)化:當數(shù)據(jù)有10條、100條、1000條甚至更多的時候,應用程序的性能不應該對應的呈數(shù)量級式的增長,否則無法使用。

說起來慚愧,我真的很少遇到性能問題。以前假設中的性能問題,很多是根本不存在的。事前計劃也杜絕了不了性能問題的產(chǎn)生,所以不如暫時忘記它吧。當然對于一些常識性的提高性能的設計,仍然是必須的。

二:iOS應用啟動速度優(yōu)化

很多app的開發(fā)者都不重視app的啟動速度,這對于碎片化使用情景的用戶來說,簡直是災難。

iOS應用的啟動速度

應用啟動時,會播放一個放大的動畫。iPhone上是400ms,iPad上是500ms。最理想的啟動速度是,在播放完動畫后,用戶就可以使用。

如果應用啟動過慢,用戶就會放棄使用,甚至永遠都不再回來。拋開代碼不談,如果抱著PC端游和單機游戲的思維,在游戲啟動時強加公司Logo,啟動動畫,并且用戶不可跳過,也會使用戶的成功使用率大大降低。

iOS系統(tǒng)的“看門狗"

為了防止一個應用占用過多的系統(tǒng)資源,開發(fā)iOS的蘋果工程師門設計了一個“看門狗”的機制。在不同的場景下,“看門狗”會監(jiān)測應用的性能。如果超出了該場景所規(guī)定的運行時間,“看門狗”就會強制終結這個應用的進程。開發(fā)者們在crashlog里面,會看到諸如0x8badf00d這樣的錯誤代碼(“看門狗”吃了壞的食物,它很不高興)。

場景“看門狗”超時時間
啟動20秒
恢復運行10秒
懸掛進程10秒
退出應用6秒
后臺運行10分鐘

值得注意的是,Xcode在Debug的時候,會禁止“看門狗”。

如何測試啟動時間

兩種方法:一種使用NSLog,另外一種使用Time Profiler。

  • 使用NSLog

 1 CFAbsoluteTime StartTime; 2 int main(int argc, char **argv) { 3      StartTime = CFAbsoluteTimeGetCurrent(); 4      // ... 5 } 6  7 - (void)applicationDidFinishLaunching:(UIApplication *)app { 8      dispatch_async(dispatch_get_main_queue(), ^{ 9         NSLog(@"Launched in %f sec", CFAbsoluteTimeGetCurrent() - StartTime);10      });11      // ...12  }
  • 使用Time Profiler

    • Instruments->Time Profiler

    • Profile你的app

    • 切換到CPU strategy view,找到你的app啟動的第一幀

    • 搜索-[UIApplication _reportAppLaunchFinished]

    • 找到包含-[UIApplication _reportAppLaunchFinished]的最后一幀,即可計算出啟動時間

iOS App啟動過程

  • 鏈接并加載Framework和static lib

  • UIKit初始化

  • 應用程序callback

  • 第一個Core Animation transaction

鏈接并加載Framework及static lib時需要注意:

  • 每個Framework都會增加啟動時間和占用的內(nèi)存

  • 不必要的Framework,不要鏈接

  • 必要的Framework,不要票房為Optional

  • 只在使用在Deployment Target之后發(fā)布的Framework時,才使用Optional(比如你的Deployment Target是iOS 3.0,需要鏈接StoreKit的時候)

  • 避免創(chuàng)建全局的C++對象

初始化UIKit時需要注意:

  • 字體、狀態(tài)欄、user defaults、main nib會被初始化

  • 保持main nib盡可能的小

  • User defaults本質(zhì)上是一個plist文件,保存的數(shù)據(jù)是同時被反序列化的,不要在user defaults里面保存圖片等大數(shù)據(jù)

應用程序的回調(diào):

  • application:willFinishLaunchingWithOptions:

  • 恢復應用程序的狀態(tài)

  • application:didFinishLaunchingWithOptions:

我一直認為設計的本質(zhì)是折衷。當你為了100ms的啟動速度優(yōu)化歡欣不已,而無視那長達10秒的啟動動畫時,應該想想究竟什么是應該做的。做正確的事情比把事情做好更重要。

三:事件處理-拯救主線程

用戶經(jīng)常評論app的一個用詞是“卡頓”,很大的因素是因為主線程被占用了。用戶的事件


新聞標題:性能優(yōu)化策略
轉載來源:http://weahome.cn/article/pgssph.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部