iOS面试题4
1.对于语句NSString* testObject = [[NSData alloc] init];testObject 在编译时和运行时分别是什么类型的对象?
编译时是NSString,运行时是NSDate
描述程序启动的顺序
1、main.m是程序的入口
2、UIApplicationMain()创建应用程序对象,并且为此对象指定委托,检测程序的执行,同时开启事件循环,处理程序接收到的事 件
3、UIApplicationDelegate方法的执行
4、加载window
5、指定根视图控制器
6、在指定的试图控制器中添加控件,实现应用程序界面
2.谈谈对性能优化的看法,如何做?
控制好内存,不用的内存实时释放;冗余代码;用户体验度;耗时操作,开线程进行处理
控制器的生命周期 以及响应链
3.简述OC中内存管理机制?。与retain配对使用的方法是dealloc还是release,为什么? 需要与alloc配对使用的方法是dealloc还是release,为什么? readwrite,readonly,assign,retain,copy,nonatomic 、atomic、strong、weak属性的作用? 并区别strong(强引用)、 weak(弱引用)? 什么情况使用copy,assign,和retain?
(1)管理机制:使用了一种叫做引用计数的机制来管理内存中的对象。OC中每个对象都对应着他们自己的引用计数,引用计数可以理解为一个整数计数器,当使用alloc方法创建对象的时候,持有计数会自动设置为1。当你向一个对象发送retain消息 时,持有计数数值会增加1。相反,当你像一个对象发送release消息时,持有计数数值会减小1。当对象的持有计数变为0的时候,对象会释放自己所占用的内存。
(2)(3)小问:
retain(引用计数加1)->release(引用计数减1)
alloc(申请内存空间)->dealloc(释放内存空间)
(4)小问:
readwrite: 表示既有getter,也有setter (默认)
readonly: 表示只有getter,没有setter
assign: 简单赋值,不更改索引计数 (默认)
retain: release旧的对象,将旧对象的值赋予输入对象,再提高输入对象的索引计数为1
copy: 其实是建立了一个相同的对象,地址不同(retain:指针拷贝 copy:内容拷贝(根据不同对象调用copy方法会产生浅拷贝, 深拷贝不同效果. 例如可变数组调用copy就是深拷贝出来一个不可变数组)
nonatomic:不考虑线程安全
atomic:线程操作安全 (默认)
线程安全情况下的setter和getter:
- (NSString*) value {
@synchronized(self) {
return [[_value retain] autorelease];
}}
(void) setValue:(NSString*)aValue {
@synchronized(self) {
[aValue retain];
[_value release];
_value = aValue;
} }
(5)问:
strong:(ARC下的)和(MRC)retain一样 (默认)
weak:(ARC下的)和(MRC)assign一样, weak当指向的内存释放掉后自动nil化,防止野指针
(6)问:
copy : 用于NSString、block等类型
assign:用于基本数据类型
retain: 用于OC对象类型