runtime相关iOS 开发 将来跳槽用

iOS-运行时(关联详解实例)

2016-05-22  本文已影响695人  船长_

基础知识:

应用场景

直接上代码

#import <UIKit/UIKit.h>
#import "objc/runtime.h"
typedef void(^blockCallBack)(NSInteger index);
@interface UIAlertView (BlockSupport)<UIAlertViewDelegate>
-(void)setCallBackBlock:(blockCallBack)block;
@end

1.设置关联对象

-(void)setCallBackBlock:(blockCallBack)block
{
    // static char kAssociatedObjectKey;
    // 将某个值跟某个对象关联起来,将某个值存储到某个对象中
    // key:通常推荐key使用static char类型——使用指针或许更好,key值是一个唯一的常量,并只在getters和setters方法内部使用objc_getAssociatedObject(self, &kAssociatedObjectKey);
    // 一个更简单的方案是:直接使用选择器(selector)因为SEL生成的时候就是一个唯一的常量,你可以使用 _cmd 作为objc_setAssociatedObject()的key
   // value:需要保存的值,这里传block,把block先保存起来,合适的地方调用
    // policy:这里的policy跟属性声明中的retain、assign、copy是一样的,不再赘述
    // objc_setAssociatedObject(<#id object#>, <#const void *key#>, <#id value#>, <#objc_AssociationPolicy policy#>)
    objc_setAssociatedObject(self, @selector(setCallBackBlock:), block, OBJC_ASSOCIATION_RETAIN_NONATOMIC);
   
    self.delegate=self;
}

2. 获取相关联的对象,执行block

-(void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex
{
    blockCallBack block=objc_getAssociatedObject(self, @selector(setCallBackBlock:));
    !block ? : block(buttonIndex);
}

3.断开关联

-(void)alertView:(UIAlertView *)alertView didDismissWithButtonIndex:(NSInteger)buttonIndex
{
    // 移除关联对象 不恰当的做法
    // 根据苹果文档描述,你不大可能有需求要自己去调用
    // 因为它也会移除掉包括其他地方加入的全部的关联对象
    // objc_removeAssociatedObjects(self);

    // 一般你只需要通过调用objc_setAssociatedObject并传入nil值来清除关联值
    objc_setAssociatedObject(self, @selector(setCallBackBlock:), nil, OBJC_ASSOCIATION_RETAIN_NONATOMIC);
}

4.用法示例

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
   UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"测试提示" message:@"这是船长的demo" delegate:self cancelButtonTitle:@"取消" otherButtonTitles:@"确定", nil];
    [alert setCallBackBlock:^(NSInteger index) {
        if (index != alert.cancelButtonIndex) {
            NSLog(@"点击了确定按钮");
        }
    }];
    [alert show];
}
上一篇 下一篇

猜你喜欢

热点阅读