iOS面试

1、如何令自己所写的对象具有拷贝功能?

实现NSCopying协议,如果自定义的对象分可变对象和不可变对象,就需要同时实现NSCopying和NSMutableCopy协议

2、说说你理解weak属性?

weak关键字在OC中数据比较基础的知识,此特性表明该属性定义一种非拥有的关系,为这种属性设置新值时,设置方法既不保留新值,也不释放旧值。此特性同assign类似,在属性所指的对象遭到销毁时,属性值也会清空。

3、如何优化Controller太臃肿的问题?

首先Controller太臃肿,就会想到设计模式MVC,很容易在C层写入大量代码,即形成了臃肿的视图控制器。可考虑:

  • 分离数据源,协议等
  • 把业务逻辑代码移到Model层
  • 把视图相关代码移动到View层

4、main()之前的过程?

首先main.m是我们熟悉的程序入口,在此之前程序还做了很多事情,简单的说可以说系统会获取dyld的路径,并加载。加载程序中的依赖库,调用所有类的+load方法,分类的+load方法,并返回main函数地址。

  • dyld开始将二进制文件初始化
  • 交由ImageLoader读取image,其中包含我们的Class,Protocol,Selector,IMP等
  • 由于runtime绑定了dyld的回调,当image加载到内存后,dyld会通知runtime进行处理
  • runtime接手后,通过map_images进行解析和处理
  • 接下来load_images中调用call_load_methods方法,遍历所有加载进来的Class,按继承层级调用Class中的+load方法和其他扩展文件的+load方法
  • 至此所有信息加载到内存中
  • 最后dyld调用真正的main函数

5、UIView和CALayer是什么关系?

UIView可以响应事件,而Layer不可以(不要说hitTest,这是只是事件传递,不是事件的响应,事件响应是靠touch系列方法)
CALayer不会直接渲染到屏幕上,UIView时iOS页面元素的基础,所有界面元素都继承自它,它本身也是完全由CoreAnimation 来实现的,真正绘图的部分时由CALayer类来管理的,一个UIView上可以由N个CALayer,每个CALayer显示一种东西,增强UIView的展现能力。

6、@synthesize 和 @dynamic 分别有什么作用?

@synthesize的语义是如果你没有实现getter和setter方法,那么编译器会自动为你加上这两个方法。
@dynamic 是告诉编译器,属性getter和setting方法由用户自己实现,不需要自动生成。
注意,如果没有setter或getter方法,在进行数据操作的时候会导致程序崩溃,编译的时候是没问题的,运行时才会执行响应的getter或setter,这也就是所谓的动态绑定。

7、为什么代理要用weak?

防止循环引用问题。

8、KVO基本原理?

当一个对象被观察的时候,系统会新建一个子类NSNotifying_A,在子类中重写了对象被观察属性的set方法,并且改变了该对象的isa指针的指向,指向新建的子类,当属性值发生改变了,会调用set方法,然后发出通知

9、objc在向一个对象发送消息时,发生了什么?

runtime库会根据对象的isa指针找到该对象的实际所属的类,然后在该类中的方法列表及父类方法列表中进行寻找方法运行,然后发送消息的时候,objc_megsend方法不会有返回值,所谓返回内容都是具体调用时执行的。
如果想一个nil对象发送消息时,首先寻找对象的isa指针时就是0地址返回的,所以不会出现任何错误。

10、静态库的原理是什么?你有没有自己写过静态编译库,遇到了哪些问题?

库本质上就是一种可执行的二进制格式,可以载入内存中执行,是程序代码的集合,共享代码的一种方式。静态库是闭源库,不公开源码,都是编译后的二进制文件,不暴露具体的实现。
静态库一般都是以.a或者.framework形式存在的,静态库的编译文件比较大,因为整合函数库的数据都会被整合到代码中,这样的好处是编译后的程序不需要外部函数库的支持,不好的一点就是如果改变静态函数库,就需要重新编译,多次使用就有多份容与拷贝。
使用静态库的好处:模块化分工合作,可重用,避免少量改动导致大量的重复编译链接。制作.a文件的时候,要注意CPU架构的支持,lipo命令进行操作。
需要注意:

  • 命名不要太随意,毕竟给别人用是要能看懂的。
  • framework中用到了NSClassFromString,但是转换出来的class 一直为nil。解决方法:在主工程的【Other Linker Flags】需要添加参数【-ObjC】即可。
  • 如果Xcode找不到框架的头文件,你可能是忘记将它们声明为public了。 解决方法:进入target的Build Phases页,展开Copy Headers项,把需要public的头文件从Project或Private部分拖拽到Public部分。
  • 尽量不要用 xib 。由于静态框架采用静态链接,linker会剔除所有它认为无用的代码。不幸的是,linker不会检查xib文件,因此如果类是在xib中引用,而没有在O-C代码中引用,linker将从最终的可执行文件中删除类。这是linker的问题,不是框架的问题(当你编译一个静态库时也会发生这个问题)。苹果内置框架不会发生这个问题,因为他们是运行时动态加载的,存在于iOS设备固件中的动态库是不可能被删除的。

你可能感兴趣的:(iOS面试)