问题:
1.怎么保证多人开发进行内存泄露的检查
答案:
1>使用Analyze进行代码的静态分析(MRC)
2>为避免不必要的麻烦,多人开发时尽量是用(ARC)
问题:
2.非自动内存管理情况下怎么做单列模式
答案:
创建单列设计模式的基本步聚
1.>声明一个单列对象的静态实例,并初始化为nil
2.>创建一个类的类工厂方法,当这个类的实例为nil时生成一个该类的实例
3.>实现NScopying协议,覆盖allocWithZone方法,确保用户在直接分配和初始化对象时,不会产生另一个对象.
4.>覆盖release autorelease retain retainCount方法,以此确保单列的状态.
5.>在多线程的环境中,注意使用@synchronized关键字GCD,确保静态实例被正确的创建和初始化.
问题:
3.对于类方法(静态方法)默认是autorelease的.所有类方法都会这样吗?
答案:
1>系统自带的绝大多数类方法返回的对象,都是经过autorelease的
问题:
4.什么情况下会发生内存泄漏和内存溢出
答案:
1>例如一个对象或者变量使用完成后没有释放,这个对象一直占用内存. (内存泄漏).
2>例如定义个int给它存储long的数,那就是(内存溢出).
问题:
5.[NSArray arrayWithobject:]这个方法添加对象后,需要对这个数组做释放操作吗?
答案:
不需要这个对象被放到自动释放池中.
问题:
6.Json数据的解析,和解析数据的时候有内存泄漏吗?有的话如何解决
(框架)
答案:
1>Json
2>JsonNkit
3>NSJsonSerialization(苹果自带)
不会发生内存泄漏
问题:
7.自动释放池底层怎么实现
答案:
1>.自动释放池以栈的形式实现:当你创建一个新的自动释放池时,它将被添加到栈顶.当一个对象收到发送autorelease消息时,它被添加到当前线程的处于栈顶的自动释放池中,当自动释放池被回收时,它们从栈中删除,并且会给池子里面所有的对象都会组一次release操作
问题:
8.KVO内部实现原理
答案:
1>KVO是基于runtiem机制实现的
2>注意: 添加通知后, 必需移除通知.
3>当某个类的对象第一次被观察时,系统就会在运行期动态得创建该类一个派生类,在这个派生类中重写基类中任何被观察属性的setter方法. (重写属性,底层实现didSet和willSet两个方法,然后通知 - (void)observeValueForKeyPath:(NSString*)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void*)context) 方法.
补充: 派生类在被重写的setter方法实现真正的通知机制
可以通过打断点查看派生类 (Person->NSKVONotifying_Person)
问题:
9.Foundation对象与Corre Foundation对象有什么区别
答案:
1>Foundation对象是OC语言,Corre Foundation对象是C语言
2>数据类型之间的转换(注意:仅仅是转换,不会对内存进行管理)
ARC: __bridge_retained ` __brideg_transfer
MRC: __bridge.
问题:
10.不用中间的变量,用两种方法交换A和B的值
答案:
方法1:
A = A + B
B = A - B
A = A – B
方法2:
a = a^b;
b = b^a;
a = a^b;