利用NSInvocation对方法进行抽象,实现对方法的加锁

简介:

我们在实际开发中须要对离散的方式加锁实现线程安全,当然我们有多种实现方式,这仅仅是当中一种,使用起来比較方便


+ (id)performSelectorWithTarget:(id)target selector:(SEL)selector withObject:(id)arg1 ,...NS_REQUIRES_NIL_TERMINATION;

{

    @synchronized(self){

        id result = nil;

        NSMethodSignature *sig = [target methodSignatureForSelector:selector];

        if (!sig) return result;

        

        NSInvocation* myInvocation = [NSInvocation invocationWithMethodSignature:sig];

        [myInvocation setTarget:target];

        [myInvocation setSelector:selector];

        int argumentStart = 2;

        va_list args;

        va_start(args, arg1); // scan for arguments after firstObject.

        

        // get rest of the objects until nil is found

        for (id obj = arg1; obj != nil; obj = va_arg(args,id)) {

            [myInvocation setArgument:&obj atIndex:argumentStart];

            argumentStart++;

        }

        

        va_end(args);

        

        [myInvocation retainArguments];

        [myInvocation invoke];

        

        //获得返回值类型

        const char *returnType = sig.methodReturnType;

        

        //声明返回值变量

        //假设没有返回值,也就是消息声明为void,那么returnValue=nil

        

        if( !strcmp(returnType, @encode(void)) ){

            

            result =  nil;

        }

        

        //假设返回值为对象。那么为变量赋值

        else if( !strcmp(returnType, @encode(id)) ){

            [myInvocation getReturnValue: &result];

        }else{

            

            //假设返回值为普通类型NSInteger  BOOL

            //返回值长度

            

            NSUInteger length = [sig methodReturnLength];

            

            //依据长度申请内存

            void *buffer = (void *)malloc(length);

            

            //为变量赋值

            

            [myInvocation getReturnValue:buffer];

            

            if( !strcmp(returnType, @encode(BOOL)) ) {

                

                result = [NSNumber numberWithBool:*((BOOL*)buffer)];

            }

            else if( !strc


mp(returnType, @encode(NSInteger)) ){

                

                result = [NSNumber numberWithInteger:*((NSInteger*)buffer)];

            }else {

                result = [NSValue valueWithBytes:buffer objCType:returnType];

            }

            

            free(buffer);

        }

        return result;

    }

}





本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/5283683.html,如需转载请自行联系原作者

相关文章
|
5天前
|
存储 人工智能 安全
AI 越智能,数据越危险?
阿里云提供AI全栈安全能力,为客户构建全链路数据保护体系,让企业敢用、能用、放心用
|
8天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
7天前
|
数据采集 人工智能 自然语言处理
3分钟采集134篇AI文章!深度解析如何通过云无影AgentBay实现25倍并发 + LlamaIndex智能推荐
结合阿里云无影 AgentBay 云端并发采集与 LlamaIndex 智能分析,3分钟高效抓取134篇 AI Agent 文章,实现 AI 推荐、智能问答与知识沉淀,打造从数据获取到价值提炼的完整闭环。
447 93
|
1天前
|
开发者
「玩透ESA」ESA启用和加速-ER在加速场景中的应用
本文介绍三种配置方法:通过“A鉴权”模板创建函数并设置触发器路由;在ESA上配置回源302跟随;以及自定义响应头。每步均配有详细截图指引,帮助开发者快速完成相关功能设置,提升服务安全性与灵活性。
285 2
|
7天前
|
SQL 人工智能 自然语言处理
Geo优化SOP标准化:于磊老师的“人性化Geo”体系如何助力企业获客提效46%
随着生成式AI的普及,Geo优化(Generative Engine Optimization)已成为企业获客的新战场。然而,缺乏标准化流程(Geo优化sop)导致优化效果参差不齐。本文将深入探讨Geo专家于磊老师提出的“人性化Geo”优化体系,并展示Geo优化sop标准化如何帮助企业实现获客效率提升46%的惊人效果,为企业在AI时代构建稳定的流量护城河。
406 156
Geo优化SOP标准化:于磊老师的“人性化Geo”体系如何助力企业获客提效46%
|
7天前
|
数据采集 缓存 数据可视化
Android 无侵入式数据采集:从手动埋点到字节码插桩的演进之路
本文深入探讨Android无侵入式埋点技术,通过AOP与字节码插桩(如ASM)实现数据采集自动化,彻底解耦业务代码与埋点逻辑。涵盖页面浏览、点击事件自动追踪及注解驱动的半自动化方案,提升数据质量与研发效率,助力团队迈向高效、稳定的智能化埋点体系。(238字)
311 158