生存不易,为了生活,为了money,自己必须强大起来。最近,马上会迎来自己的面试高峰期,自己搜集了一些非常容易被面试官提及的iOS基础面试题,特总结归纳并自己凑不要脸的回答一下(排序不分先后以及重要程度)。
Here we go!
- TCP、UDP协议和区别?
TCP (Transmission Control Protocal, 传输控制协议):提供的是面向连接、可靠的字节流服务。当客户Client和服务器Server彼此交换数据前,必须在双方之间建立一个TCP连接,之后才可以传输数据。
UDP (User Data Protocal, 用户数据报协议):是一个简单的面向数据报的运输层协议。UDP并不可靠,它只是把应用程序传给IP层的数据报发送出去,但是并不能保证到达目的地。就是说我只管发,至于到不到,那我不能保证。传输过程无需建立连接,数据快于TCP。
这里侧重说明一下TCP连接的三次“握手”:
1. 主机A向主机B发送连接请求数据包;
2. 主机B向主机A发送同意连接和要求同步(一个发送、一个接收,协调工作)的数据包;
3. 主机A向主机B发送确认同步数据包;
区别:
是否面向连接、传输是否可靠、传输数据量大小、速度快慢
- iOS内存管理机制 & ARC?
说明内存管理机制之前,先讲一个经典的内存泄露的例子:
1) 一个对象创建并保留计数器的值为1的对象A;
2) 对象A创建并保留计数器的值为1的对象B并将其作为子对象;
3) 对象A创建了对象B,所以对象A拥有一个指向对象B的强引用;如果对象B有一个指向对象A的强引用,那么对象A的保留计数器的值会增加到2;
4) 当对象A的拥有者向对象A发送release消息,这样会让对象A的保留计数器的值减少到1;
这样,由于对象A所创建的对象B的保留计数器的值仍为1,所以对象A和B都没有被释放掉,造成了内存泄露。
解决办法:使用弱引用。
弱引用不会增加保留计数器的值,因此当对象A的拥有者释放它的时候,它的保留计数器的值会变成0,它也会释放对象B。
归零弱引用:指向的对象释放之后,这些弱引用就会被设置为零(即nil)。
__weak NSString *myString;
@property (weak) NSString *myString;
Cocoa的内存管理规则:
- 如果使用new、alloc或copy操作获得一个对象,则该对象的保留计数器的值为1;
- 如果通过其他方法获得一个对象,则假设该对象的保留计数器的值为1,而且已经被设置为自动释放;
- 如果保留了某对象,则必须保持retain方法和release方法的使用次数相同;
ARC (automatic reference counting) 会在编译过程中通过插入这些语句来帮组你执行保留或释放操作。
copy,retain,assign的区别?
•copy:把原来的对象完整的赋值到另外一地方,重新加载一内存区,一个地方变了不影响另一个地方的对象。
•assign:简单的直接赋值,相当于说两个对象指向同个内存区,一个地方的变了,其他的也跟着改变。
•retain:释放旧的对象,将旧对象的值赋予输入对象,再提高输入对象的索引计数为1
那上面的是什么意思呢?
copy其实是建立了一个相同的对象,而 retain 不是:
比如一个NSString对象,地址为0×1111,内容为@”ABC”;
copy 到另外一个NSString之 后,地址为0×2222,内容相同,新的对象retain 为 1,旧 有对象没有变化;
retain 到另外一个NSString之 后,地址相同(建立一个指针,指针拷贝),内容当然相同,这个对象的 retain 值+1;
assign 地址还是0x1111,内容也还是“ABC”。
也就是说,retain 是指针拷贝,copy 是内容拷贝。
- KVO,Noification &Delegate 区别?
在功能上说,delegate、Notification以及KVO的功能类似,都是作用于OC中对象的消息通信。但三者的使用场景是不同的。简单的说Delegate是一种回掉函数,更多的用在一对一的场合;Notification 用得较少,使用Notification Center,类似广播方式,所以更适合一对多的通信;KVO,key-Value-Observing,观察者模式,适用于侦听另一对象的属性的变化。
如何选择KVO,Noification &Delegate?
请参考这里 IOS 如何选择delegate、notification、KVO?