【iOS系列】-oc中特有的语法

oc数据类型:

 1,基本类型
2,对象类型
3,id
4,BOOL
5,block
6,SEL

1:category

使用继承关系来扩充一个类,有一个弊病,高耦合性

category(分类,类别)

能够帮我们扩充一个类的功能

1,只要是在原类中生成的成员变量都可以在分类中直接访问,不能在分类中生成员变量

2,如果分类中定义实现了与原类中相同的方法,那么原类中的方法相当于被覆盖掉了。

注:在实际的开发中,最好不要出现方法覆盖

//指向函数的指针
void test()
{
NSLog(@"test");
}
void (*myTest)() = test;
myTest();

2:block 指向函数的指针比较像

block就是弥补了 指向函数的指针,不能够直接保存一个函数体(代码块)

//定义(无返回值)
void (^myBlock)() = ^{
NSLog(@"test");
};
//调用
myBlock(); //定义(有返回值)
int (^sumBlock)(int a, int b) = ^int (int a, int b) { return a + b;
};
//调用
int result = sumBlock(10,20);

注:如果想要改变,block代码块之外的变量值,就必须在变量前加入 __block关键字

3:protocol(协议)

意思同:java中的接口

1,谁遵循协议,谁就要实现协议中定义的方法

2,协议文件本身只是提供方法的声明,并不实现方法

3,协议本身也可以遵循其他协议,NSObject是一个基础协议,协议也可以同时遵循多个其他协议

4,父类遵循了那些协议,子类同样遵循那些协议

5,一个类可以同时遵循多个协议

@required//下面的方法,必须实现,默认都是必须实现的

@optional //下面的方法,可选实现

4:SEL:包装方法

- (void)test1;
- (void)test2:(NSString *)n;
- (NSString *)test3; //无参数
[t test1];
//使用@selector就能够把一个方法包装成 SEL数据类型
SEL s1 = @selector(test1);
//包装后的方法的执行
[p performSelector:s1];
//或者这样调用,更为常用一些
[p performSelector:@selector(test1)]; //带参数
SEL s2 = @selector(test2:); [p performSelector:s2 withObject:@"135047654"]; //带返回值
SEL s3 = @selector(test3); NSString * str = [p performSelector:s3];
05-04 06:34