协议定义了一系列方法,遵从协议的对象应该实现它们。我们可以用协议把自己写的API隐藏自来,将返回的对象设计为遵从协议的id类型。想要隐藏的类名就不会出现在API中了。如果接口背后有多个不同的实现类,而你又不想指明具体使用哪个类,可以考虑用这个办法,因为有时候这些类可能会变。
@property (nonatomic, weak) id<lykDelegate>delegate;
由于该属性是id<lykDelegate>,所以任何类的对象都可以充当这个属性,即使该类不继承自NSObject,只要遵循lykDelegate协议就可以。如果有需要,可以在运行期查出此对象所属的类型。
NSDictionary:在字典中,键的标准内存语义是“设置时拷贝”,值得内存语义是“设置时保留”。因此,可变版本中,设置键值对所用的方法是
- (void)setObject:(ObjectType)anObject forKey:(KeyType <NSCopying>)aKey;
表示键的那个参数可以是任意类型,只要遵从NSCopying协议就行,这样,就可以向对象发送拷贝消息了。
总结:
1.协议可以提供匿名类型。具体对象类型可以淡化为id类型,协议里规定了对象应该实现的具体方法。
2.使用匿名对象来隐藏类型名称。
3.类型不重要,重要的是对象能够响应的方法,这种情况可以用匿名对象来表示。
@property (nonatomic, weak) id<lykDelegate>delegate;
由于该属性是id<lykDelegate>,所以任何类的对象都可以充当这个属性,即使该类不继承自NSObject,只要遵循lykDelegate协议就可以。如果有需要,可以在运行期查出此对象所属的类型。
NSDictionary:在字典中,键的标准内存语义是“设置时拷贝”,值得内存语义是“设置时保留”。因此,可变版本中,设置键值对所用的方法是
- (void)setObject:(ObjectType)anObject forKey:(KeyType <NSCopying>)aKey;
表示键的那个参数可以是任意类型,只要遵从NSCopying协议就行,这样,就可以向对象发送拷贝消息了。
总结:
1.协议可以提供匿名类型。具体对象类型可以淡化为id类型,协议里规定了对象应该实现的具体方法。
2.使用匿名对象来隐藏类型名称。
3.类型不重要,重要的是对象能够响应的方法,这种情况可以用匿名对象来表示。