iOS笔记--面试题01

问题:

1.怎么保证多人开发进行内存泄露的检查

答案:

1>使用Analyze进行代码的静态分析(MRC)

2>为避免不必要的麻烦,多人开发时尽量是用(ARC)


问题:

2.非自动内存管理情况下怎么做单列模式


答案:

创建单列设计模式的基本步聚

1.>声明一个单列对象的静态实例,并初始化为nil

2.>创建一个类的类工厂方法,当这个类的实例为nil时生成一个该类的实例

3.>实现NScopying协议,覆盖allocWithZone方法,确保用户在直接分配和初始化对象时,不会产生另一个对象.

4.>覆盖release autorelease retain retainCount方法,以此确保单列的状态.

5.>在多线程的环境中,注意使用@synchronized关键字GCD,确保静态实例被正确的创建和初始化.

iOS笔记--面试题01_第1张图片


iOS笔记--面试题01_第2张图片

问题:

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.不用中间的变量,用两种方法交换AB的值

答案:

方法1:

A = A + B

B = A - B

A = A – B

方法2:

a = a^b;

b = b^a;

a = a^b;


如何生成XML


iOS笔记--面试题01_第3张图片

你可能感兴趣的:(iOS笔记--面试题01)