首页 > 系统 > iOS > 正文

iOS常见宏理解及使用方法

2020-07-26 02:19:21
字体:
来源:转载
供稿:网友

FOUNDATION_EXPORT, UIKIT_EXTERN

该宏的作用类似于extern,使用方法也与extern类似,在.m文件中,定义如下

 NSString *const kFoundationExportString = @"Hello World";  NSString *const kExternString = @"Hello World";

然后在.h文件中加上以下声明, 就可以在导入该.h文件的类中访问该常量。

 FOUNDATION_EXPORT NSString *const kFoundationExportString;  extern NSString *const kExternString; 

如果要在未导入该.h文件的类中访问这两个常量, 则应该将上面的代码放入该类的.m文件中。

UIKIT_EXTERN相比extern只是增加了兼容性,使用方法一样。

使用如下:

 NSString *str = @"Hello World"; if (str == kConstantString) { NSLog(@"equal"); }

使用FOUNDATION_EXPORT声明的字符串常量比较的是指针的地址, 而#define宏定义的常量字符串只能使用isEqualToString来比较, 前者更加高效。

define与FOUNDATION_EXPORT比较

NS_STRING_ENUM 和 NS_EXTENSIBLE_STRING_ENUM

这两个个宏定义是用于为Objective-C桥接Swift所使用的,它的作用是在桥接到 Swift 中时可进行枚举扩展,使用如下:

在.h文件中声明

 typedef NSString *ViewControllerKey NS_STRING_ENUM; FOUNDATION_EXPORT ViewControllerKey const ViewControllerKeyTitle; FOUNDATION_EXPORT ViewControllerKey const ViewControllerKeySubtitle; FOUNDATION_EXPORT ViewControllerKey const ViewControllerKeySummary;

.m文件中定义:

 ViewControllerKey const ViewControllerKeyTitle = @"title"; ViewControllerKey const ViewControllerKeySubtitle = @"subtitle"; ViewControllerKey const ViewControllerKeySummary = @"summary"; 

在swift文件中使用如下:

 print("/(ViewControllerKey.title) /(ViewControllerKey.subtitle) /(ViewControllerKey.summary)")

这两个宏定义的区别在于,NS_STRING_ENUM是确定的, NS_EXTENSIBLE_STRING_ENUM则是可扩展的,还可以在在swift中进行扩展。

__VA_ARGS__

##就是个粘合剂,将前后两部分粘合起来,也就是有“字符化”的意思。

而__VA_ARGS__在预编译中会被实参列表取代, ...表示可变参列表。

##__VA_ARGS__ 宏前面加上##的作用在于,当可变参数的个数为0时,这里的##起到把前面多余的,去掉的作用,否则会编译出错

 #define BLOCK_EXEC(block, ...) if (block) { block(__VA_ARGS__); }; #ifdef DEBUG #define LogInfo( s, ... ) NSLog( @"[LogInfo]<%@:(%d)> %@", [[NSString stringWithUTF8String:__FILE__] lastPathComponent], __LINE__, [NSString stringWithFormat:(s), ##__VA_ARGS__] ) #else #define LogInfo( s, ... ) #endif

源码地址:Github: ZpFate/DefineDemo (本地下载)

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对武林网的支持。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表