- 如何在不改变原来类模型的前提下,给类扩充一些方法?有2种方式
@interface类名 (分类名称) // 方法声明 @end @implementation类名 (分类名称) // 方法实现 @end
- 一个庞大的类可以分模块开发
- 一个庞大的类可以由多个人来编写,更有利于团队合作
- 给NSString增加一个类方法:计算某个字符串中阿拉伯数字的个数
- @“abc434an34”
- unichar c = [str characterAtIndex:0]; 返回第一个字符
给NSString增加一个对象方法:计算当前字符串中阿拉伯数字的个数
- Category可以访问原始类的实例变量,但不能添加变量,只能添加方法。如果想添加变量,可以考虑通过继承创建子类
- Category可以实现原始类的方法,但不推荐这么做,因为它是直接替换掉原来的方法,这么做的后果是再也不能访问原来的方法
- 多个Category中如果实现了相同的方法,只有最后一个参与编译的才会有效
- 其实类也是一个对象,是Class类型的对象,简称“类对象”
- Class类型的定义
typedef struct objc_class *Class;
- 在程序启动的时候会加载所有的类和分类,并调用所有类和分类的+load方法
- 先加载父类,再加载子类;也就是先调用父类的+load,再调用子类的+load
- 先加载元原始类,再加载分类
- 不管程序运行过程有没有用到这个类,都会调用+load加载
- +initialize (初始化--调用)-- 可以用来监听类的初始化过程,
- 在第一次使用某个类时(比如创建对象等),就会调用一次+initialize方法
- 一个类只会调用一次+initialize方法,先调用父类的,再调用子类的
- 分类的 +initialize 会 覆盖 类 中的 加载
Class c = [Person class];// 类方法 或者 Person*p = [Person new]; Class c2 = [p class];// 对象方法
Class c = [Person class]; Person *p2 = [c new];
- -description方法--决定了实例对象的输出结果
使用NSLog和%@输出某个对象时,会调用对象的-description方法,默认返回值 是 <类名 +内存地址 > ,并拿到返回值进行输出 默认情况下,利用NSLog和%@输出对象时,结果是<类名:内存地址>,字符串除外 - +description方法--决定了类对象的输出结果
使用NSLog和%@输出某个类对象时,会调用类对象+description方法,并拿到返回值进行输出 默认输出类名 - 重写-description或者+description方法即可
- 如果在-description方法中使用NSLog打印self
- 每个类的方法列表都存储在类对象中
- 每个方法都有一个与之对应的SEL类型的对象
- 根据一个SEL对象就可以找到方法的地址,进而调用方法
- SEL类型的定义
typedef struct objc_selector *SEL;
SEL s = @selector(test); 将字符串转成SEL 数据,从而调用该方法 SEL s2 = NSSelectorFromString(@"test");
// 将SEL对象转为NSString对象 NSString *str = NSString FromSelector(@selector(test));
Person *p = [Personnew]; // 调用对象p的test方法 [p performSelector:@selector(test)]; [p performSelector:@selector(test:) withObject:@“123”]; 方法名 包含冒号
- __FILE__ :源代码文件名
- NSLog(@"%s", __FILE__); 输出不能有中文 应该用printf
- __LINE__ :NSLog代码在第几行 NSLog(@"%d", __LINE__);
- _cmd :代表着当前方法的SEL
// 下面的代码会引发死循环 - (void)test { [self performSelector:_cmd]; }
|