Objective-C分类 (category)和扩展(Extension)

时间:2023-01-15 16:24:48

1、分类(category)

使用Object-C中的分类,是一种编译时的手段,允许我们通过给一个类添加方法来扩充它(但是通过category不能添加新的实例变量),并且我们不需要访问类中的代码就可以做到,这点和javascript中使用原型来定义属性有点类似。

我们可以为一个类创建一个新的方法,而不需要在代码中编辑类定义。

下面就是定义并使用分类的例子程序,通过下面代码,我们可以给Object-C中的NSString 添加camelCaseString分类,使用camelCaseString方法,就可以去掉一个字符串中的空格,并将原有空格后的单词改写成大写(即 将字符串转化为驼峰式)。

  1. #import <Foundation/Foundation.h>
  2. /*
  3. 定义分类的过程大致可分为以下几个步骤:
  4. 第一步、创建一个带有接口的新文件,即创建已有类
  5. 第二步、在新文件中添加需要扩展的方法及方法的实现,即需要添加的分类
  6. */
  7. //NSString 表示将要添加分类的类名称,该类必须是已存在的。
  8. //CamelCase 是为类添加的方法名称。
  9. //只能添加方法,不能添加变量。
  10. //头文件命名惯例:ClassName+CategoryName.h
  11. @interface NSString (CamelCase)
  12. -(NSString*) camelCaseString;
  13. @end
  14. @implementation NSString (CamelCase)
  15. -(NSString*) camelCaseString
  16. {
  17. //调用NSString的内部方法获取驼峰字符串。
  18. //self指向被添加分类的类。
  19. NSString *castr = [self capitalizedString];
  20. //创建数组来过滤掉空格, 通过分隔符对字符进行组合。
  21. NSArray *array = [castr componentsSeparatedByCharactersInSet:
  22. [NSCharacterSet whitespaceCharacterSet]];
  23. //把数组的字符输出
  24. NSString *output = @"";
  25. for(NSString *word in array)
  26. {
  27. output = [output stringByAppendingString:word];
  28. }
  29. return output;
  30. }
  31. @end
  32. int main (int argc, const char * argv[])
  33. {
  34. NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
  35. NSString *str = @"My name is bill.";
  36. NSLog(@"%@", str);
  37. str = [str camelCaseString];
  38. NSLog(@"%@", str);
  39. [pool drain];
  40. return 0;
  41. }

2、扩展(Extension)

关于扩展,你可以这样理解:扩展是一种匿名分类;但是和匿名分类不一样的是,扩展可以添加新的实例变量(是不是觉得扩展已经强大到非一般的地步了? ^_^)

从Xcode 4 之后就推荐在自定义类的.m文件中使用扩展,这样就能保证良好的代码封装性,避免把私有接口暴露给外面。

下面是一个扩展的例子:

    1. @interface MyClass : NSObject
    2. - (float)value;
    3. @end
    4. @interface MyClass () { //注意此处:扩展
    5. float value;
    6. }
    7. - (void)setValue:(float)newValue;
    8. @end
    9. @implementation MyClass
    10. - (float)value {
    11. return value;
    12. }
    13. - (void)setValue:(float)newValue {
    14. value = newValue;
    15. }
    16. @end