- Objective-C 基础
- Objective-C - 首页
- Objective-C - 概述
- Objective-C - 环境设置
- Objective-C - 程序结构
- Objective-C - 基本语法
- Objective-C - 数据类型
- Objective-C - 变量
- Objective-C - 常量
- Objective-C - 运算符
- Objective-C - 循环
- Objective-C - 决策
- Objective-C - 函数
- Objective-C - 块
- Objective-C - 数字
- Objective-C - 数组
- Objective-C - 指针
- Objective-C - 字符串
- Objective-C - 结构体
- Objective-C - 预处理器
- Objective-C - Typedef
- Objective-C - 类型转换
- Objective-C - 日志处理
- Objective-C - 错误处理
- 命令行参数
- 高级 Objective-C
- Objective-C - 类和对象
- Objective-C - 继承
- Objective-C - 多态
- Objective-C - 数据封装
- Objective-C - 类别
- Objective-C - 伪装
- Objective-C - 扩展
- Objective-C - 协议
- Objective-C - 动态绑定
- Objective-C - 复合对象
- Obj-C - Foundation 框架
- Objective-C - 快速枚举
- Obj-C - 内存管理
- Objective-C 有用资源
- Objective-C - 快速指南
- Objective-C - 有用资源
- Objective-C - 讨论
Objective-C 扩展
类扩展与类别有一些相似之处,但它只能添加到我们在编译时拥有源代码的类中(类与类扩展同时编译)。
类扩展声明的方法在原始类的实现块中实现,因此,例如,您不能在框架类(例如 Cocoa 或 Cocoa Touch 类,如 NSString)上声明类扩展。
扩展实际上是没有类别名称的类别。它通常被称为**匿名类别**。
声明扩展的语法使用 @interface 关键字,就像标准的 Objective-C 类描述一样,但没有指示从子类继承。相反,它只是添加了括号,如下所示:
@interface ClassName () @end
扩展的特征
扩展不能声明为任何类,只能声明为我们拥有原始源代码实现的类。
扩展添加了仅特定于类的私有方法和私有变量。
在扩展中声明的任何方法或变量甚至对继承的类也无法访问。
扩展示例
让我们创建一个名为 SampleClass 的类,该类有一个扩展。在扩展中,让我们有一个私有变量 internalID。
然后,让我们有一个方法 getExternalID,它在处理 internalID 后返回 externalID。
示例如下所示,这在在线编译器上不起作用。
#import <Foundation/Foundation.h>
@interface SampleClass : NSObject {
NSString *name;
}
- (void)setInternalID;
- (NSString *)getExternalID;
@end
@interface SampleClass() {
NSString *internalID;
}
@end
@implementation SampleClass
- (void)setInternalID {
internalID = [NSString stringWithFormat:
@"UNIQUEINTERNALKEY%dUNIQUEINTERNALKEY",arc4random()%100];
}
- (NSString *)getExternalID {
return [internalID stringByReplacingOccurrencesOfString:
@"UNIQUEINTERNALKEY" withString:@""];
}
@end
int main(int argc, const char * argv[]) {
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
SampleClass *sampleClass = [[SampleClass alloc]init];
[sampleClass setInternalID];
NSLog(@"ExternalID: %@",[sampleClass getExternalID]);
[pool drain];
return 0;
}
现在,当我们编译并运行程序时,我们将获得以下结果。
2013-09-22 21:18:31.754 Extensions[331:303] ExternalID: 51
在上面的示例中,我们可以看到 internalID 没有直接返回。我们在这里删除 UNIQUEINTERNALKEY,并且仅使剩余的值可用于方法 getExternalID。
上面的示例仅使用字符串操作,但它可以具有许多功能,例如加密/解密等等。
广告