首先要明确 #pragma 和_Pragma 是什么
这两个都是出自于c/c++ 的 ,其中#pragma 是预处理指令(preProcess directive ) ,#pragma是用来向编译器传达语言标准以外的一些信息。 ;
_Pragma操作符,该操作符具有与 #pragma 指令相同的功能
_Pragma(token-string)
相比预处理指令#pragma,_Pragma操作符可用于宏定义中的内联。 #pragma 指令不能用于宏定义中,因为编译器会将指令中的数字符号(“#”)解释为字符串化运算符 (#)。
由于_Pragma是一个操作符,因此可以用在一些宏中,我们可以看看下面这个例子:
#define ArgumentToString(macro) #macro
#define ClangWarningConcat(warning_name) ArgumentToString(clang diagnostic ignored warning_name)
/// 参数可直接传入 clang 的 warning 名,w
#define BeginIgnoreClangWarning(warningName) _Pragma("clang diagnostic push") _Pragma(ClangWarningConcat(#warningName))
#define EndIgnoreClangWarning _Pragma("clang diagnostic pop")
#define BeginIgnorePerformSelectorLeaksWarning BeginIgnoreClangWarning(-Warc-performSelector-leaks)
#define EndIgnorePerformSelectorLeaksWarning EndIgnoreClangWarning
_Pragma("clang diagnostic push") \
_Pragma("clang diagnostic ignored \"-Warc-performSelector-leaks\"") \
if( [self.delegate respondsToSelector:@selector(next:)]){
[ self.delegate performSelector:@selector(next:) withObject:obj ] ;
}
_Pragma("clang diagnostic pop") \
//上面代码可以替换成
BeginIgnorePerformSelectorLeaksWarning
if( [self.delegate respondsToSelector:@selector(next:)]){
[ self.delegate performSelector:@selector(next:) withObject:obj ] ;
}
EndIgnorePerformSelectorLeaksWarning
上面这个例子如果 self 没实现 next:方法 ,且没有对应的 代理, 则会提示 没有相关方法 , 通过使用_pragma 就能取消提示
相关参数 可查看 :https://clang.llvm.org/docs/DiagnosticsReference.html#wpragma-clang-attribute
关于提示:
#error "this is en Error"
#waring "this a warn message"