欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

2018年iOS面试真题

程序员文章站 2022-06-07 23:42:05
...

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面试真题
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面试真题
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))