运行 [p test]; //1.首先把test包装成SEL类型的数据,在去类中找相对应的SEL(Person这个类:SE地址L s1 == test)
//2.根据SEL数据找到对应的方法地址
//3.根据方法地址调用对应的方法
间接调用test方法:
[p performSelector:@selector(test2)];// 传入SEL
有参数:
[p test3:@"123"];
或者:
[p performSelector:@selector(test3) withObiect:@"456"];// 传入SEL
发消息发的是SEL
方法的存储位置:
每个类的方法列表都存储在类对象中
每个方法都有一个与之对应的SEL类型的对象
根据一个SEL对象就可以找到方法的地址,进而调用方法
SEL类型的定义:
typedef struct objc selector *SEL
SEL对象的创建:
SEL s = @selector(test);
[p performSelector:s withObiect:@"456"];// 传入SEL
SEL s2 = NSSelectorFromString(@"test");
知道方法名的字符串:
NSString *name = @"test2";
SEL s = NSSelectorFromString(name);
[p performSector:s];
_cmd 是SEL类型的,代表当前方法
_cmd == @selector(test2);
NSString *str = NSStringFromSector(_cmd);
NSLog(@"%@",str);// 输出当前方法名
- (void)test2
{
[self performSelector:_cmd];//死循环
}
SEL:
其实是对方法的一种包装,将方法包装成一个SEL类型的数据,去找对应的方法地址,找到方法地址就可以调用方法
其实消息就是SEL
//2.根据SEL数据找到对应的方法地址
//3.根据方法地址调用对应的方法
间接调用test方法:
[p performSelector:@selector(test2)];// 传入SEL
有参数:
[p test3:@"123"];
或者:
[p performSelector:@selector(test3) withObiect:@"456"];// 传入SEL
发消息发的是SEL
方法的存储位置:
每个类的方法列表都存储在类对象中
每个方法都有一个与之对应的SEL类型的对象
根据一个SEL对象就可以找到方法的地址,进而调用方法
SEL类型的定义:
typedef struct objc selector *SEL
SEL对象的创建:
SEL s = @selector(test);
[p performSelector:s withObiect:@"456"];// 传入SEL
SEL s2 = NSSelectorFromString(@"test");
知道方法名的字符串:
NSString *name = @"test2";
SEL s = NSSelectorFromString(name);
[p performSector:s];
_cmd 是SEL类型的,代表当前方法
_cmd == @selector(test2);
NSString *str = NSStringFromSector(_cmd);
NSLog(@"%@",str);// 输出当前方法名
- (void)test2
{
[self performSelector:_cmd];//死循环
}
SEL:
其实是对方法的一种包装,将方法包装成一个SEL类型的数据,去找对应的方法地址,找到方法地址就可以调用方法
其实消息就是SEL