1. 怎么在多人開發(fā)時進(jìn)行內(nèi)存泄漏的檢測敛滋?
- 使用Analyze進(jìn)行代碼的靜態(tài)分析;
- 為避免不必要的麻煩,多人開發(fā)時盡量使用ARC
2. 非ARC情況下怎么做單例模式?
- 創(chuàng)建單例設(shè)計模式的基本步驟:
- 聲明一個單例對象的靜態(tài)實例捷兰,并初始化為nil;
- 創(chuàng)建一個類的類工廠方法负敏,當(dāng)且僅當(dāng)這個類的實例為nil時生成一個該類的實例贡茅;
- 實現(xiàn)NSCopying協(xié)議,覆蓋allocWithZone:方法其做,確保用戶在直接分配和初始化對象時友扰,不會產(chǎn)生另一個對象;
- 覆蓋release庶柿、autorelease、retain秽浇、retainCount方法浮庐,以此確保單例的狀態(tài);
- 在多線程的環(huán)境中柬焕,注意使用@synchronized關(guān)鍵字或GCD审残,確保靜態(tài)實例被正確的創(chuàng)建和初始化。
3. 對于類方法(靜態(tài)方法)默認(rèn)是autorelease的斑举,所有類方法都會這樣嗎搅轿?
- 系統(tǒng)自帶的絕大多數(shù)類方法返回的對象都是經(jīng)過autorelease的
4. block在ARC中和MRC中的用法有什么區(qū)別,需要注意什么富玷?
- 對于沒有引用外部變量的Block璧坟,無論在ARC還是非ARC下,類型都是__NSGlobalBlock__赎懦,這種類型的block可以理解成一種全局的block雀鹃,不需要考慮作用域的問題。同時励两,對它進(jìn)行Copy或者Retain操作也是無效的黎茎;
- 應(yīng)注意避免循環(huán)引用
5. 什么情況下會發(fā)生內(nèi)存泄漏和內(nèi)存溢出?
- 當(dāng)程序在申請內(nèi)存后当悔,無法釋放已申請的內(nèi)存空間(例如一個對象或者變量使用完成沒有釋放傅瞻,這個對象一直占用著內(nèi)存),一次內(nèi)存泄漏危害可以忽略盲憎,但是內(nèi)存泄漏堆積后果很嚴(yán)重嗅骄,無論多少內(nèi)存,遲早會被占光焙畔。 內(nèi)存泄漏會最終導(dǎo)致內(nèi)存溢出掸读!
- 當(dāng)程序在申請內(nèi)存時,沒有足夠的內(nèi)存空間供其使用,出現(xiàn)out of memory儿惫;比如申請一個int澡罚,但是給它存了long才能存下的數(shù),那就是內(nèi)存溢出肾请。
6. [NSArray arrayWithObject:<id>]
這個方法添加對象后留搔,需要對這個數(shù)組做釋放操作嗎?
- 不需要铛铁,這個對象被放到自動釋放池中
7. JSON數(shù)據(jù)的解析方案隔显?解析數(shù)據(jù)的時候有內(nèi)存泄漏嗎?有的話饵逐,如何解決括眠?
- JSON解析的方案:
SBJSON
JSONKit
NSJSONSerialization
- 看解析的方法和實現(xiàn),一般來說倍权,比較少會出現(xiàn)內(nèi)存泄漏掷豺。內(nèi)存泄漏和JSON數(shù)據(jù)解析本身沒太大關(guān)系。
8. 自動釋放池底層是怎么實現(xiàn)的薄声?
- 自動釋放池以棧的形式實現(xiàn):當(dāng)創(chuàng)建一個新的自動釋放池時当船,它將被添加到棧頂。當(dāng)一個對象收到發(fā)送autorelease消息時默辨,他被添加到當(dāng)前線程的處于棧頂?shù)淖詣俞尫懦刂械缕担?dāng)自動釋放池被回收時,它從棧中被刪除缩幸,并且會給池子里面所有的對象都會做一次release操作壹置。