iOS-SEL的用法和讲解

热门标签

特别声明:文章多为网络转载,资源使用一般不提供任何帮助,特殊资源除外,如有侵权请联系!

1:什么是SEL:
可理解成@selector(),方法选择器。于是乎就可说成是C中的指针函数。而在oc里不能用指针函数,所有就只能搞一个@selector这来取了。
他的结果是SEL类型,用assgin修饰。去取方法的编号(函数地址)

2:使用
2.1 示例代码
SELView.h

/**SEL实现*/
#import <UIKit/UIKit.h>

@interface SELView : UIView

/**自定义的SEL*/
@property (nonatomic, assign) SEL  customMethod;
/**正常调用函数*/
-(void)printfString:(NSString *)msg;

/**SEL调用*/
-(void)testMethod;
/**SEL调用带参数*/
-(void)testMethod:(NSString *)msg;

-(void)runMethod;
@end

SELView.m

#import "SELView.h"

@implementation SELView

-(void)printfString:(NSString *)msg {
    NSLog(@"-----printfString%@",msg);
}

/**无参数函数*/
-(void)testMethod{
    NSLog(@"-----testMethod");
}
/**有参数函数*/
-(void)testMethod:(NSString *)msg {
    NSLog(@"-----(有参数函数)testMethod:%@",msg);
}


-(void)runMethod{
    if (_customMethod) {
        [self performSelector:_customMethod withObject:nil];
    }
}

2.2 调用详解

//实例化对象
SELView *views = [[SELView alloc] init];

2.2.1 正常调用的方式如下

[views printfString:@"1:自定义的打印功能"];

2.2.2 传入SEL方法调用
NOTICE:这里我们用的@selector方法一定要是当前SEL类中的函数,应为当前Class是一个isa指针,而这个@selector就是调用当前isa中方法,取其中的编号。

/**传入的方法*/
views.customMethod = @selector(testMethod);

这里的testMethod就是当前views中的方法。否则当前对象无target,就会有错!
2.2.3 执行Selector和传参

/**无参数函数*/
[views performSelector:@selector(testMethod)];
/**有参数函数*/
[views performSelector:@selector(testMethod:) withObject:@"传入参数"];

2.2.4 SEL和NSString装换

/**将一个字符串转换成SEL类型*/
//SEL s1 = NSSelectorFromString(@"customClick");
SEL s2 = @selector(customClick);
[self performSelector:s2];

NOTICE:这个时候会有一个提示performselectorm may cause a leak because its selector is unknow,在ARC模式下,运行时需要知道如何处理你正在调用的方法的返回值。这个返回值可以是任意值,如 void , int , char , NSString , id 等等。ARC通过头文件的函数定义来得到这些信息。所以平时我们用到的静态选择器就不会出现这个警告。因为在编译期间,这些信息都已经确定。
而使用 [someController performSelector: NSSelectorFromString(@"customClick")]; 时ARC并不知道该方法的返回值是什么。最后搞的什么鬼都不认识了。如何处理 请各位看官看我的下一篇文章。如何解决。

 

标签:

未经允许不得转载:作者:SheaYang, 转载或复制请以 超链接形式 并注明出处 技术Dog|博客
原文地址:《iOS-SEL的用法和讲解》 发布于2019-09-27

分享到:
赞(0) 打赏

评论 抢沙发

4 + 6 =


iOS-SEL的用法和讲解

长按图片转发给朋友

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏

Vieu4.0主题
专业打造轻量级个人企业风格博客主题!专注于前端开发,全站响应式布局自适应模板。

登录

忘记密码 ?