A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© S970028126 中级黑马   /  2015-6-29 20:59  /  677 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 S970028126 于 2015-6-29 21:01 编辑

SEL:
        其实是对方法的一种包装,将方法包装成一个SEL类型的数据,去找对应的方法地址,找到方法地址就可以调用方法
        其实消息就是SEL
p对象调动test方法的一个过程
           [p test]://1.首先把test包装成SEL类型的数据
                         //2.根据SEL数据找到对应的方法地址
                         //3.根据方法地址调用对应的方法
SEL对象的创建:
        SEL s = @selector(test);
直接调用test方法:
        [p test];
间接调用test方法:
        [p performSelector: @selector(test)]; // 传入SEL
有参数的方法调用:
        [p test3: @"123"];
        或者使用SEL:
                [p performSelector: @selector(test3) withObject: @"456"];// 传入SEL        
        
        发消息发的是SEL
                方法的存储位置:
                        每个类的方法列表都存储在类对象中
                        每个方法都有一个与之对应的SEL类型的对象
                        根据一个SEL对象就可以找到方法的地址,进而调用方法                        

        知道方法名的字符串,可以转化为SEL类型:
                例如:
                NSString *name = @"test2";
                SEL s = NSSelectorFromString(name);
                [p performSector: s];

        _cmd 是SEL类型的,代表当前方法
        _cmd == @selector(test);

        NSString *str = NSStringFromSector(_cmd); //将SEL转化为字符串类型
        NSLog(@"%@",str);// 输出当前方法名

下面的写法会造成死循环:        
    - (void)test
        {
                [self performSelector:  _cmd];//死循环
        }

        

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马