关于#pragma 和 _pragma

首先要明确 #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"
上一篇:[Effective C++]条款01:视C++为一个语言联邦


下一篇:【Python】Object Oriented Programming