#pragma

#pragma声明主要由Xcode用来完成两个主要任务——整理代码和防止编译器警告。

整理代码

代码的整洁程度反映了程序员及其代码的靠谱程度。缺少惯性和一致性的代码表明作者要么疏忽要么无能,更遭到的是,使得一个项目难以维护和协作。

好的习惯从#prama mark开始。就像这样:

@implementation ViewController

- (id)init { 
  ...
}

#pragma mark - UIViewController

- (void)viewDidLoad {
  ...
}

#pragma mark - IBAction

- (IBAction)cancel:(id)sender {
  ...
}

#pragma mark - UITableViewDataSource

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
  ...
}

#pragma mark - UITableViewDelegate

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
  ...
}

在你的@implementation中使用#pragma mark ,将代码分割成多个逻辑块。这些逻辑区块不仅使得阅读代码本身容易许多,也为Xcode源导航增加了视觉线索。

一个好的习惯是将一个类里面的所有方法根据它们的来源组合放在一起。比如,来源UITableViewDelegate的所有方法放在一起并在这些方法前加入#pragma mark - UITableViewDelegate标注。

防止警告

#pragma mark同样可以用来防止来自编译器或者静态分析器的警告,这点用的比较少。

比糟糕格式的代码更烦人的是生成警告的代码。尤其是第三方类库的代码。可是,绝大多数时候没有办法避免编译器警告。在某些罕见的场景中,你绝对肯定一个编译器异常或者静态分析器异常需要被抑制,那么#prama就派上了用场:

// completionBlock在AFURLConnectionOperation中被手动的设置为nil来打破保留周期。
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Warc-retain-cycles"
    self.completionBlock = ^ {
        ... 
    };
#pragma clang diagnostic pop

幸运的是,Clang提供了一个便捷的方法解决了这一切。通过使用#prama clang diagnostic push/pop, 你可以告诉编译器针对某一特定部分代码来忽视特定的警告。

你可以在Clang Compiler User's Manual读到更多关于#pragma的LLVM用法的知识。

只是不要用这种方法来清扫合法的警告,这会在后续工作中带来很大的麻烦。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前面一段时间,不是在忙离职,就是趁着清明跑去放(fu)松(bai)去了,好久了都没开始真正的写一写iOS相关的...
    redihd阅读 4,771评论 1 4
  • 作为预处理指令,#pragma 在编译时进行计算。但它并不像如 #ifdef…#endif 之类的宏,#pragm...
    小DB阅读 809评论 0 2
  • 在所有的预处理指令中,#Pragma 指令可能是最复杂的了,它的作用是设定编译器的状态或者是指示编译器完成一些特定...
    進无尽阅读 449评论 0 0
  • 哲学是什么? 这个问题如何回答,其实每个人都有自己关于哲学的看法,每个人都有自己的哲学观,因此每个人都有意或无意地...
    狂奔的蜗牛_eb65阅读 678评论 0 0
  • 那一声声早晚安,是多么苍白无力。 对于一个感性的我来说,我又不知如何表达。 但我也只能说出这样平淡无味的话。 等,...
    凡夫俗子y阅读 116评论 5 6