2018年iOS面试真题

3月面试真题

本套真题是笔者的一位朋友去小苏苏面试分享的,答案由笔者及其朋友总结,如有问题请及时纠正。

1.内存管理
内存管理:是对内存资源进行优化。内存管理三种方式:ARC(自动内存管理)、MRC(手动内存管理)、内存池。
(1)、MRC(MannulReference Counting)手动引用计数 ,iOS 5.0之前采用的内存管理机制,需要程序员手动的创建对象申请内存,然后再手动的释放。
MRC管理内存的原则:谁创建,谁释放,谁引用,谁管理。
在使用MRC时,当创建或引用一个对象的时候,需要向她发送alloc、copy、retain消息,当释放该对象时需要发送release消息,当对象引用计数为0时,系统将释放该对象。
(2)、ARC(Automatic Reference Counting)自动引用计数。iOS 5.0之后采用的内存管理机制。在代码中自动加入了retain/release,由编译器自动管理计数+1和释放。
在使用ARC时,需要设置正确的property属性(strong、weak、copy关键字),不然可能出现内存泄露。
(3)、内存池:autorelease是在创建对象的时候写的,表示加入自动释放池,当释放池销毁时,才调用引用计数-1。
2.哪些类和UIView有继承关系(直接或间接的父类、子类关系)
2018年iOS面试真题_第1张图片
3.OC的消息机制
参考消息机制
4.优秀的设计原则
高内聚、低耦合
5.OC或swift的冒泡算法

  /*冒泡排序法的基本思想:(以升序为例)含有n个元素的数组原则上要进行n-1次排序。对于每一躺的排序,从第一个数开始,依次比较前一个数与后一个数的大小。 
 如果前一个数比后一个数大,则进行交换。这样一轮过后,最大的数将会出现称为最末位的数组元素。第二轮则去掉最后一个数,对前n-1个数再按照上面的步骤找出最 
 大数,该数将称为倒数第二的数组元素......n-1轮过后,就完成了排序。*/
    NSMutableArray *numbers = [NSMutableArray arrayWithObjects:@"17",@"28",@"36",@"15",@"39", nil];
    NSLog(@"排序前%@",numbers);
    for (int i = 0; i < 5 - 1; i++) {
        //比较的躺数
        for (int j = 0; j < 5 - 1 - i; j++) {
            //比较的次数
            if ([numbers[j] intValue] > [numbers[j + 1] intValue]) {
                //这里为升序排序
                int temp = [numbers[j] intValue];
                numbers[j] = numbers[j + 1];
                //OC中的数组只能存储对象,所以这里转换成string对象
                numbers[j + 1] = [NSString stringWithFormat:@"%d",temp];
            }
        }
    }
    NSLog(@"排序后%@",numbers);

6.线程问题
2018年iOS面试真题_第2张图片
7.为什么代理要使用关键字weak,代理里面的delegate和dataSource有什么区别
(1)防止循环引用,weak会在对象引用计数为0的时候自动释放。具体参考iOS 为什么要用weak修饰代理。
(2)datasource协议里面东西是跟内容有关的,主要是cell的构造函数,各种属性。
delegate协议里面的方法主要是操作相关的,移动编辑之类的,你都写上要用什么方法自己去翻就是了 。
8.什么时候会报unrecognized selector错误?iOS用那些机制来避免走到这一步
(1)、
对象未实现该方法。
对象已经被释放。
(2)、
- 使用[id respondsToSelector:]进行判断。
- Method resolution:objc运行时会调用+resolveInstanceMethod:或者 +resolveClassMethod:,让你有机会提供一个函数实现。如果你添加了函数,那运行时系统就会重新启动一次消息发送的过程,否则 ,运行时就会移到下一步,消息转发(Message Forwarding)。返回Nil和self,去调用第三步methodSignatureForSelector和forwarInvocation;返回receiver,如果receiver有响应就直接处理,如果没有就去对应的对象内去调用第三步;调用子类的函数,子类没有进行这几个方法的重载,在父类处理时返回子类,会死循环。
- Fast forwarding:如果目标对象实现了-forwardingTargetForSelector:,Runtime 这时就会调用这个方法,给你把这个消息转发给其他对象的机会。 只要这个方法返回的不是nil和self,整个消息发送的过程就会被重启,当然发送的对象会变成你返回的那个对象。否则,就会继续Normal Fowarding。 这里叫Fast,只是为了区别下一步的转发机制。因为这一步不会创建任何新的对象,但下一步转发会创建一个NSInvocation对象,所以相对更快点。
- Normal forwarding:这一步是Runtime最后一次给你挽救的机会。首先它会发送-methodSignatureForSelector:消息获得函数的参数和返回值类型。如果-methodSignatureForSelector:返回nil,Runtime则会发出-doesNotRecognizeSelector:消息,程序这时也就挂掉了。如果返回了一个函数签名,Runtime就会创建一个NSInvocation对象并发送-forwardInvocation:消息给目标对象。
9.介绍下分类,说下能用分类做什么?内部是如何实现的?分类中如果实现了类的相同方法会出现什么情况?
category:是为已经存在的类添加方法。
功能:
a)可以把不同的功能组织到不同的category里
b)可以有多个开发者共同完成一个类
c)可以按需加载想要的category等等。
d)减少文件数量。
内部实现:
category的方法没有完全替换掉原来类已经有的方法,而是和原有方法共存,并排在了原有方法的前面。编译时是按照顺序查找的,因此会执行category的方法。
10.写一个“标准”宏MIN,这个宏输入两个参数并返回较小的一个

#define MIN(a,b) ((a)>(b)?(b):(a))

你可能感兴趣的:(【开发积累】)