面向对象开发的四大特性
封装
继承
多态性
数据隐藏
- 定义常量两种方法
1 使用#define预处理器
2 使用const关键字 - 使用#define预处理器的格式
#define identifier value
- 使用const关键字
const type variable = value;
- 函数形式
- (return_type) function_name:(argumentType1)argumentName1
joiningArgument2:(argumentType2)argumentName2
joningArgument:(argumentType)argument{
body of functionn
}
- 要以对象形式保存数据类型如int 、float、bool,oc提供了一系列与NSNumber一起使用的方法,常用重要方法如下:
- 非正式协议
非正式协议就是类别,凡是NSObject或其子类的类别,都是非正式协议 - 类别和类扩展
1.类别的写法:
@interface NSString (CamlCase)
- (NSString *) CamlCaseString
@end
这里的CamlCase就是类别名称,跟类名一样不能重复,类别只能增加方法,不能增加实例变量
2.类扩展的写法
@interface MyClass (){
float value;
}
- (void)setValue:(float)newValue;
@end
这种写法的类别叫匿名类别,又叫类扩展,所谓的扩展,其实就是为一个类添加额外的原来没有的变量,方法或者合成属性
类别与类扩展的区别
①类别中只能增加方法
②类扩展中不仅可以增加方法,还可以增加实例变量(或者合成属性),只是该实例变量都是@private类型的(作用范围只能在自身类,而不是子类或其他地方)
③类扩展中声明的方法没被实现,编译器会报警,但是类别中的方法没被实现编译器是不会有任何警告的。这是因为类扩展实在编译阶段被添加到类中,而类别是在运行时添加到类中
④类扩展不能像类别那样拥有独立的实现部分(@implementation部分),也就是说,类扩展所声明的方法必须依托对应类的实现部分来实现
⑤定义在.m文件中的类扩展方法为私有的,定义在.h文件中的类扩展方法为公有的,类扩展是在.m文件中声明私有方法的非常好的方式正式协议
正式协议值得是一一个以@protocal方式命名的方法列表,与非正式以相比不同的是,他要求显示的采用协议
1.正式协议的方法类型
①@required
该类的方法在遵守相应协议的类中是必须被实现的,不然编译器会告警(显然这是在编译时做的检查而不是运行时)
②@optional
该类的方法在遵守相应协议的类中是否已实现是可选的
2.正式协议存在的意义
从字面上理解,正式协议比非正式协议要正式了很多,他存在的意义在于:
正式协议可以将业务中的方法定义剥离出来,形成一个单独的文件,这跟传统oo中的提取接口是不谋而合的。如果遇到两个系统需要交换数据,可以指定一套双方都遵守的协议,然后这两个系统中都把这个协议文件添加到项目中,实现它既可
3.继承性
正式协议和类一样,是可以继承的,书写格式同类继承相似
@protocal NewProtocal <Protocal>