category与associative作为objective-c的扩展机制的两个特性,category即类型,可以通过它来扩展方法;associative,可以通过它来扩展属性;在iOS开发中,可能category比较常见,相对的associative,就用的比较少,要用它必须使用<objc/runtime.h>的头文件,然后就可以自由使用objc_getAssociatedObject以及objc_setAssociatedObject,我们来看下这两个方法:
__OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_1);
OBJC_EXPORT id objc_getAssociatedObject(id object, const void *key)
__OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_1);
另外还有一个方法:
__OSX_AVAILABLE_STARTING(__MAC_10_6, __IPHONE_3_1);
objc_getAssociatedObject、objc_setAssociatedObject、objc_removeAssociatedObjects都是Obj-c中的外联方法,object 参数作为待扩展的对象实例,key作为该对象实例的属性的键,而value就是对象实例的属性的值,policy作为关联的策略,它的枚举包括:
OBJC_ASSOCIATION_ASSIGN = 0,
OBJC_ASSOCIATION_RETAIN_NONATOMIC = 1,
OBJC_ASSOCIATION_COPY_NONATOMIC = 3,
OBJC_ASSOCIATION_RETAIN = 01401,
OBJC_ASSOCIATION_COPY = 01403
};
具体我就多说了,可以看得懂的。
另外,objc_removeAssociatedObjects可以删除指定对象实例的所有扩展属性。
这里,定义了一个"alert view"的按钮:
[viewController.view addSubview:button];
button.frame = CGRectMake(50, 50, 100, 44);
[button setTitle:@"alert view" forState:UIControlStateNormal];
现在对UIButton通过使用category对其进行方法扩展:
…...
- (void)handleControlEvent:(UIControlEvents)event withBlock:(void(^)(id sender))block {
NSString *methodName = [UIControl eventName:event];
NSMutableDictionary *opreations = (NSMutableDictionary*)objc_getAssociatedObject(self, &OperationKey);
if(opreations == nil)
{
opreations = [[NSMutableDictionary alloc] init];
objc_setAssociatedObject(self, &OperationKey, opreations, OBJC_ASSOCIATION_RETAIN);
}
[opreations setObject:block forKey:methodName];
[self addTarget:self action:NSSelectorFromString(methodName) forControlEvents:event];
}
objc_getAssociatedObject,objc_setAssociatedObject进行属性扩展:
OperationKey是一个字符类型,这里表示一个键,如果Opreations为空,会setAssociatedObject一个新的opreations对象到对应键的值中间。
addTarget:action:forControlEvents对于触摸事件进行目标绑定。
NSSelectorFromString(methodName) 将触发方法:
-(void)UIControlEventTouchDownRepeat{[self callActionBlock:UIControlEventTouchDownRepeat];}
-(void)UIControlEventTouchDragInside{[self callActionBlock:UIControlEventTouchDragInside];}
-(void)UIControlEventTouchDragOutside{[self callActionBlock:UIControlEventTouchDragOutside];}
-(void)UIControlEventTouchDragEnter{[self callActionBlock:UIControlEventTouchDragEnter];}
-(void)UIControlEventTouchDragExit{[self callActionBlock:UIControlEventTouchDragExit];}
-(void)UIControlEventTouchUpInside{[self callActionBlock:UIControlEventTouchUpInside];}
-(void)UIControlEventTouchUpOutside{[self callActionBlock:UIControlEventTouchUpOutside];}
-(void)UIControlEventTouchCancel{[self callActionBlock:UIControlEventTouchCancel];}
-(void)UIControlEventValueChanged{[self callActionBlock:UIControlEventValueChanged];}
-(void)UIControlEventEditingDidBegin{[self callActionBlock:UIControlEventEditingDidBegin];}
-(void)UIControlEventEditingChanged{[self callActionBlock:UIControlEventEditingChanged];}
-(void)UIControlEventEditingDidEnd{[self callActionBlock:UIControlEventEditingDidEnd];}
-(void)UIControlEventEditingDidEndOnExit{[self callActionBlock:UIControlEventEditingDidEndOnExit];}
-(void)UIControlEventAllTouchEvents{[self callActionBlock:UIControlEventAllTouchEvents];}
-(void)UIControlEventAllEditingEvents{[self callActionBlock:UIControlEventAllEditingEvents];}
-(void)UIControlEventApplicationReserved{[self callActionBlock:UIControlEventApplicationReserved];}
-(void)UIControlEventSystemReserved{[self callActionBlock:UIControlEventSystemReserved];}
-(void)UIControlEventAllEvents{[self callActionBlock:UIControlEventAllEvents];}
注意到这里会去执行callActionBlock:方法:
NSMutableDictionary *opreations = (NSMutableDictionary*)objc_getAssociatedObject(self, &OperationKey);
if(opreations == nil) return;
void(^block)(id sender) = [opreations objectForKey:[UIControl eventName:event]];
if (block) block(self);
}
最终会从扩展属性中得到^block,关于^block可以参考:http://blog.csdn.net/pjk1129/article/details/6577097
最后调用:
UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"alert"
message:nil
delegate:nil
cancelButtonTitle:@"ok"
otherButtonTitles:@"other",nil];
}];
点击按钮就会触发一个block函数。
source:https://github.com/zhangxigithub/BlockUI
相关推荐
基于神经元网络和 Linear Auto-Associative memory 和pca的人脸识别程序。
基于忆阻神经网络的联想记忆,曾志刚,温世平,本文研究了基于忆阻神经网络的联想记忆。根据忆阻器二极模型的阻值的可变性,提出一种带有非对称电压阈值一维电压控制模型。由于
N路集关联缓存C / C ++中的直接映射和N-Way集关联高速缓存模拟器,用于处理器中的L1高速缓存创建二进制文件? 在Linux终端中使用make命令获取二进制文件命令参数? 级别1数据缓存模拟器应接受以下命令行选项: -s &...
单元对象关联记忆 探索想法 每个单元格都可以像杰森一样 它们是类似Lua表的关联记忆。 json是关联内存或表的实际字符串表示形式。 但是,出于讨论目的,Json仅被视为与关联存储器或lua表相同,后者可以转换为字符串...
multi-label lazy associative classifier, which progressively exploits dependencies among labels. Further, since in our lazy strategy the classification model is in- duced on an instance-based fashion,...
PHP Arrays Single Multi-dimensional Associative and Object Arrays in PHP 7 英文无水印pdf pdf所有页面使用FoxitReader和PDF-XChangeViewer测试都可以打开 本资源转载自网络,如有侵权,请联系上传者或csdn...
## 8-Way设置关联缓存8路组关联缓存的Verilog实现作为BSF Pilani KK Birla Goa校园的CSF342计算机体系结构的课程项目提交。 ###注意,我仅出于好奇心上载了此项目的github存储库。 由于有些学生在搜索作业时可能会...
PHP Arrays Single, Multi-dimensional, Associative and Object Arrays in PHP 7 英文无水印原版pdf pdf所有页面使用FoxitReader、PDF-XChangeViewer、SumatraPDF和Firefox测试都可以打开 本资源转载自网络,如...
Structure of Two-Groups Associative Rings (1990年)
Apress.PHP.Arrays.Single.Multi-dimensional.Associative.and.Object.Arrays.in.PHP.7.1484225554.rar 最新书籍,精讲PHP数组,文字版PDF
代码描述了category与associative作为objective-c的扩展机制的两个特性,和Runtime的动态机制的应用。
MATLAB IMPLEMENTATION OF BIDIRECTIONAL ASSOCIATIVE MEMORY
注意:虽然帮助功能建议支持 n-associative 缓存,但还没有任何用于建模 n-associative 缓存的规定。 目前仅支持直接关联。 此外,当前实施的唯一替换策略是先进先出 (FIFO) 策略,尽管其意图是在未来支持最近最少...
(EDMA) Controller (128 Independent Set-Associative) Channels) – 64K-Byte L2 Unified Mapped RAM/Cache · Video Hardware Accelerators (4-Way Set-Associative) – POWERVR SGX™ 2D/3D Graphics – 32K-Byte...
基于方面的情感分析(ABSA)试图预测相对于给定方面实体的给定文档的极性。尽管神经网络体系结构已经成功地预测了句子的整体极性,但是方面情感分析仍然是一个悬而未决的问题。在本文中,我们提出了一种整合方面信息...
local-slackwarearm-repo.sh-SAREPO [v2.0.3]-2021年3月13日版权所有(c)2021 Exaga -罗萨尔皮项目- Version - 08 Mar 2021 [v0.1a] - progenitor - 10 Mar 2021 [v1] - associative array mechanics - 12 Mar ...
联想记忆神经网络(Associative Memory),用于分类