======文档更新状态=====
2015-12-21:发布
==================
day07-[2015-12-18]
一、分类和扩展
1.分类语法:
@interface 原类名 (分类名)
//扩展的方法,属性(一般较少)声明
@end
@implementation 原类名 (分类名)
//扩展的方法的实现,属性的getter和setter的实现
@end
2.在使用分类时,如果只导入原类的头文件是无法访问分类新增内容的;必须导入分类的头文件才可以
2.分类的使用
1.给父类增加的分类方法,子类也会继承下来,但有前提:一定要让子类能够“见到”分类头文件,可以在子类的头文件中包含,也可以在使用子类的文件中包含
2.分割复杂的类,由不同分类给出部分方法的实现
3.替代原类中的同名方法:前提是分类文件参与编译,无需嵌入分类的头文件;如果分类的m文件参与编译,则原类的方法一定被分类的同名方法覆盖而无效;如果有多个分类的实现中都有同名方法,则在编译选项(Build Phases—>Compile Sources)中位置靠后的分类方法有效,位置靠前的均被覆盖而失效;以上均与头文件是否导入无关
4.访问“私有”方法:在原类中没有声明但有实现的方法,可以在分类中声明后就可以访问了;相当于分类中只有声明,没有实现,将实现放在原类中完成
5.作为非正式协议:
A.定义一个NSObject的分类,只有头文件,没有m文件,在头文件中定义若干方法(仅有方法声明)
B.在需要遵循这个非正式协议的类中导入该分类头文件
C.在遵循这个非正式协议的类的实现部分给出非正式协议中方法的实现
3.分类的应用
1.为NSString增加一个方法:-(NSString*)reverse;
用于将当前字符串(ASCII)反转后返回
“abcd” “dcba”
2.作为非正式协议
一些其它解释
一、分类Category
1.功能:为已有类增加新的方法、属性(较少用到)
2.语法:@interface 已有类名 (分类名)
//方法、属性声明
@end
@implementation 已有类名 (分类名)
//方法实现
//属性的getter、setter的实现
@end
3.使用:要想使用分类新增方法,必须导入分类头文件
4.在分类中增加属性,前提是能够修改原类代码
A.在分类声明部分和普通属性一样先声明
B.在原类声明中定义对应的私有成员变量
C.在分类或原类的实现部分给出setter和getter的实现
5.同一操作的2种不同理解
A。通过分类让原类的“私有”方法变成公有的
B。分类中声明的方法,不在分类中实现,而是在原类中实现
6.通过分类覆盖原类方法的实现,相当于重写:在分类的实现部分中,给出原类已有方法的实现(无需在分类的声明部分再次声明该方法),则当对象访问该方法时,分类的新实现会覆盖掉原类的实现,不管是否导入分类头文件;如果不想覆盖,可以通过修改项目的编译参数(在 Build Phase —> Complie Sources中增减参与编译的m文件)解决
7.如果多个分类都重写了原类的方法,则以编译顺序决定,编译顺序可以手动设置;原类的方法实现不可能覆盖分类的实现。
8.分类中新增的方法、属性,原类的子类一样可以继承,前提是在使用前(在子类的声明部分、或main函数前……)导入分类的头文件;分类重写的方法无需导入分类头文件
9.为系统已有类增加方法:
为NSString增加一个reverse方法,功能是反转字符串
例如:@“abcde”—>@“edcba”
10.使用分类实现非正式协议
A.定义一个NSObject的分类,只保留头文件,在其中声明方法规范
B.在子类的头文件中导入分类头文件
C.在子类的实现文件中给出分类中声明的方法的实现
11.注意非正式协议与正式协议的区别
// 代码太多--->已经上传至网盘
// http://pan.baidu.com/s/1i4cfbNJ
二、扩展Extension
1. 只有声明部分,类似于匿名分类:
@interface 原类名 ()
{
//成员变量
}
//属性和方法
@end
2.但是可以有成员变量、属性和方法;没有实现部分,实现要在原类中完成
一些其它解释
二、扩展Extension
1.作用:为自定义类(也可以是有源代码的类)增加新的成员变量、属性、方法
2.语法:@interface 已有类名(){
//成员变量
}
//属性、方法声明
@end
3.没有实现文件,必须在原类中给出方法的实现,一般是在原类的实现文件(m文件)中导入扩展文件,再给出方法实现、重写属性的getter/setter等
// YYBook.h
#import <Foundation/Foundation.h>
@interface YYBook : NSObject
@property (nonatomic,copy)NSString* title;
@property (nonatomic,assign)int price;
-(instancetype)initWithTitle:(NSString*)title price:(int)price;
@end
// YYBook.m
#import "YYBook_Ext.h"
@implementation YYBook
-(instancetype)initWithTitle:(NSString *)title price:(int)price{
if (self=[super init]) {
self.title=title;
self.price=price;
}
return self;
}
-(NSString *)description{
return [NSString stringWithFormat:@"Book %@'s price is %d",_title,_price];
}
-(void)sell{
NSLog(@"Book %@ (Author:%@,Pages:%d) is selling!",_title,_author,pages);
}
@end
// YYBook_Ext.h
#import "YYBook.h"
@interface YYBook ()
{
@public
int pages;
}
@property (nonatomic,copy)NSString* author;
-(void)sell;
@end
// test_book.m
#import "YYBook_Ext.h"
int main(){
YYBook* bk=[[YYBook alloc]initWithTitle:@"iOS入门" price:100];
NSLog(@"book:%@",bk);
bk->pages=99;
bk.author=@"Jobs";
[bk sell];
return 0;
}
============EOF======