基础知识点整理
从iOSInterviewQuestions中摘录了个人认为重要且容易遗忘的知识点。
1、什么情况使用weak关键字,相比assign有什么不同?
- 在ARC中,有可能出现循环引用的时候用weak或者assign申明属性。
- 已经对属性进行了一次强引用,没有必要在强引用一次的情况。比如:IBOutlet控件一般使用weak。
2、怎么使用copy关键字?
(1) NSString、NSArray、NSDictionary 等经常使用copy关键字,因为他们有对应的可变类型。为了保护属性的封装性,防止申明的属性在不知情的情况下被改变,需要用copy关键字拷贝出一份不可变副本。
(2)block也使用copy修饰。在传统的MRC中,方法内部的block是在栈区,使用copy可以把block放到堆区。
3、@property (copy) NSMutableArray 写法会有什么问题?
- 需要注意,用copy修饰后得到的是一个不可变的副本,所以不能调用可变数组才有的方法。
- 用默认的automic关键字申明属性,会影响性能。
4、@protocol 和 category 中使用 @property
- 在protocol 中使用property只会生成setter 和 getter 方法,在protocol使用属性的目的就是希望遵循该协议的对象能实现该属性。
- category 也只会生成setter 和 getter 方法,如果要给category增加属性的实现,需要借助runtime的两个函数
objc_setAssociatedObject
和objc_getAssociatedObject
。
5、什么时候@property 使用 setter=<name>
的情形。
- 在数据反序列化、转模型过程中,服务器返回的字段如果以
init
开头,编译器会把'init'开头的方法当成初始化方法,而初始化方法只能返回self类型,因此编译器会报错。
6、@用@property声明的NSString(或NSArray、NSDictionary),如果用strong关键字可能会出现的问题。
- 该属性有可能指向一个可变对象,如果该可变对象在外部被修改,那么就会影响该属性。
7、对非集合类对象
的copy操作
copy | mutableCopy | |
---|---|---|
immutableObject | 浅拷贝 | 深拷贝 |
mutableObject | 深拷贝 | 深拷贝 |
8、对 集合类对象
进行copy操作
copy | mutableCopy | |
---|---|---|
immutableObject | 浅拷贝 | 单层深拷贝 |
mutableObject | 单层深拷贝 | 单层深拷贝 |
9、自动合成属性实例变量后,@synthesize 的使用场景。
- 同时重写了setter 和getter方法时
- 重写了只读属性的gtter方法时
- 使用了@dynamic 时
- 在@protocol中定义的所有属性
- 在@category中定义的所有属性
- 重载属性:当在子类中重载了父类中的属性,必须使用
@synthesize
来手动合成ivar - 重新制定实例变量的名字
10、objc中向一个对象发送消息[objc foo] 和 objc_msgSend()函数之间有什么关系
[objc foo];
在动态编译时会被转译为
objc_msgSend(objc,@selector(foo))
11、什么时候会报unrecognized selector
异常?
- 在向一个对象发送消息时,runtime会根据该对象的isa指针找到该对象所属的类,然后在该类和该类的父类的方法列表中找方法运行,
如果在最顶层的父类中也没有找到该方法,则会抛出异常。
12、一个objc的对象的isa指针指向哪里?有何作用?
指向其所属的类,从而可以在该类的方法列表中找到对象的方法。
13、self
和 super
关键字的理解。
-
self
指向当前调用方法的这个的实例。 -
super
和self
一样都是指向当前调用方法这个类的实例。不同之处在于self
调用的方法是从当前类中去获取,而super
关键字则告诉编译器要去当前这个类的父类的方法列表中获取方法。