我所理解的內(nèi)存管理纯路,介紹一下內(nèi)存管理或油。
答:采用引用計數(shù)管理對象內(nèi)存,當持有該對象驰唬,則引用計數(shù)加1顶岸,不需要了引用計數(shù)減1腔彰,當應用計數(shù)為零的時候,被放入釋放池辖佣,釋放掉霹抛。如果不是OC對象,則要自己管理內(nèi)存卷谈,例如調(diào)用C語言函數(shù)杯拐,獲取方法數(shù)組: Method *methodList = class_copyMethodList(class, &count); 使用完之后,要調(diào)用C函數(shù)free(methodList)雏搂,釋放內(nèi)存藕施。
MRC和ARC的區(qū)別寇损,以及你的理解凸郑。
自動釋放池的理解。
自動釋放池在MRC和ARC的區(qū)別矛市。
block的實現(xiàn)原理芙沥,以及你的理解。
block在MRC和ARC下有什么區(qū)別浊吏。
block 變量修飾詞有哪些而昨,都有那些作用。
答:針對局部變量找田,全局變量歌憨,全局靜態(tài)變量,局部靜態(tài)變量墩衙,block捕獲后都做了哪些處理务嫡,在這個鏈接下面說的很清楚。
https://blog.csdn.net/li15809284891/article/details/62896569
多層自動釋放池嵌套的對象在那一層釋放漆改。
autorealsepool什么時候釋放心铃。
屬性的理解,strong挫剑,weak去扣,assign。
如果屬性完全不加修飾詞用weak樊破,atomic愉棱,系統(tǒng)會怎么處理。
weak的實現(xiàn)原理哲戚。
深拷貝和淺拷貝的理解奔滑,為什么是這樣。
category和extension的區(qū)別惫恼,系統(tǒng)如何底層實現(xiàn)的档押。
消息轉(zhuǎn)發(fā)機制實現(xiàn)。
KVO簡單介紹一下:
答:
1.如果使用
a.監(jiān)聽某個對象的屬性
- (void)addObserver:(NSObject *)observer forKeyPath:(NSString *)keyPath options:(NSKeyValueObservingOptions)options context:(nullable void *)context;
b.實現(xiàn)協(xié)議
- (void)observeValueForKeyPath:(nullable NSString *)keyPath ofObject:(nullable id)object change:(nullable NSDictionary *)change context:(nullable void *)context;
c.移除監(jiān)聽
- (void)removeObserver:(NSObject *)observer forKeyPath:(NSString *)keyPath;
底層實現(xiàn)原理:KVO是通過isa-swizzling技術實現(xiàn)的。運行時根據(jù)原類創(chuàng)建一個中間類令宿,這個中間類是原類的子類叼耙,并動態(tài)修改當前對象的isa指針指向中間類,并且將class 方法重寫粒没,返回原類的class筛婉。蘋果建議通過class 實例方法來獲取對象類型。
CSDN:https://www.cnblogs.com/guohai-stronger/p/9473551.html
掘金:https://juejin.im/post/5aef18b76fb9a07aa34a28e6
當某個類的對象在第一次被觀察時癞松,系統(tǒng)會在運行時動態(tài)創(chuàng)建一個該類的子類爽撒,在該子類中重寫setter方法真正實現(xiàn)通知機制;派生類重寫了 class 方法以“欺騙”外部調(diào)用者它就是起初的那個類响蓉。然后系統(tǒng)將這個對象的isa指針指向這個新誕生的派生類硕勿,因此這個對象就成為該派生類的對象了,因而在該對象上對setter的調(diào)用就會調(diào)用重寫的setter枫甲,從而激活鍵值通知機制源武。此外,派生類還重寫了dealloc方法來釋放資源想幻。
如何聲明一下全局變量粱栖。
答:
1.在AppDelegate.h 中聲明的變量,因為AppDelegate是單利脏毯,并且程序內(nèi)所有文件都可用闹究。
2.extern NSString * const 修飾的變量;
如何分析crash,以及如何收集crash食店。
請看這里: http://www.reibang.com/p/ade5f6acf4d8