美文网首页
代码组织

代码组织

作者: 维维_iOS | 来源:发表于2016-11-22 14:44 被阅读0次

    来自 Mattt Thompson

    code organization is a matter of hygiene (代码组织是卫生问题)
    

    利用代码块

    一个 GCC 非常模糊的特性,以及 Clang 也有的特性是,代码块如果在闭合的圆括号内的话,会返回最后语句的值
    
    NSURL *url = ({
        NSString *urlString = [NSString stringWithFormat:@"%@/%@", baseURLString, endpoint]; 
        [NSURL URLWithString:urlString];
    });
    

    Pragma

    Pragma Mark

    <pre>#pragma mark - 是一个在类内部组织代码并且帮助你分组方法实现的好办法。 我们建议使用 #pragma mark - 来分离:
    </pre>

    · 不同功能组的方法
    · protocols 的实现
    · 对父类方法的重写
    
    - (void)dealloc { /* ... */ }
    - (instancetype)init { /* ... */ }
    #pragma mark - View Lifecycle (View 的生命周期)
    - (void)viewDidLoad { /* ... */ }
    - (void)viewWillAppear:(BOOL)animated { /* ... */ }
    - (void)didReceiveMemoryWarning { /* ... */ }
    #pragma mark - Custom Accessors (自定义访问器)
    - (void)setCustomProperty:(id)value { /* ... */ }
    - (id)customProperty { /* ... */ }
    #pragma mark - IBActions 
    - (IBAction)submitData:(id)sender { /* ... */ }
    #pragma mark - Public
    - (void)publicMethod { /* ... */ }
    #pragma mark - Private
    - (void)zoc_privateMethod { /* ... */ }
    #pragma mark - UITableViewDataSource
    - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { /* ... */ }
    #pragma mark - ZOCSuperclass
    // ... 重载来自 ZOCSuperclass 的方法
    #pragma mark - NSObject
    - (NSString *)description { /* ... */ }
    

    上面的标记能明显分离和组织代码。你还可以用 cmd+Click 来快速跳转到符号定义地方。 但是小心,即使 paragma mark 是一门手艺,但是它不是让你类里面方法数量增加的一个理由:类里面有太多方法说明类做了太多事情,需要考虑重构了。

    关于 pragma

    http://raptureinvenice.com/pragmas-arent-just-for-marks/ 有很好的关于 pragma 的讨论了,在这边我们再做部分说明。
    大多数 iOS 开发者平时并没有和很多编译器选项打交道。一些选项是对控制严格检查(或者不检查)你的代码或者错误的。有时候,你想要用 pragma 直接产生一个异常,临时打断编译器的行为。
    当你使用ARC的时候,编译器帮你插入了内存管理相关的调用。但是这样可能产生一些烦人的事情。比如你使用NSSelectorFromString来动态地产生一个 selector 调用的时候,ARC不知道这个方法是哪个并且不知道应该用那种内存管理方法,你会被提示 performSelector may cause a leak because its selector is unknown(执行 selector 可能导致泄漏,因为这个 selector 是未知的).
    如果你知道你的代码不会导致内存泄露,你可以通过加入这些代码忽略这些警告

    #pragma clang diagnostic push
    #pragma clang diagnostic ignored "-Warc-performSelector-leaks"[myObjperformSelector:mySelector withObject:name];
    #pragma clang diagnostic pop
    

    注意我们是如何在相关代码上下文中用 pragma 停用 -Warc-performSelector-leaks 检查的。这确保我们没有全局禁用。如果全局禁用,可能会导致错误。
    全部的选项可以在 The Clang User's Manual 找到并且学习。

    忽略没用使用变量的编译警告

    告诉你申明的变量它将不会被使用,这种做法很有用。大多数情况下,你希望移除这些引用来(稍微地)提高性能,但是有时候你希望保留它们。为什么?或许它们以后有用,或者有些特性只是暂时移除。无论如何,一个消除这些警告的好方法是用相关语句进行注解,使用 #pragma unused():

    - (NSInteger)giveMeFive
    { 
      NSString *foo; 
      #pragma unused (foo) 
      return 5;
    }
    

    现在你的代码不用任何编译警告了。注意你的 pragma 需要标记到问题代码之下。

    明确编译器警告和错误

    编译器是一个机器人,它会标记你代码中被 Clang 规则定义为错误的地方。但是,你总是比 Clang 更聪明。通常,你会发现一些讨厌的代码会导致这个问题,但是暂时却解决不了。你可以这样明确一个错误:

    - (NSInteger)divide:(NSInteger)dividend by:(NSInteger)divisor
    {
       #error Whoa, buddy, you need to check for zero here! 
       return (dividend / divisor);
    }
    

    类似的,你可以这样标明一个警告

    - (float)divide:(float)dividend by:(float)divisor
    {
       #warning Dude, don't compare floating point numbers like this!
       if (divisor != 0.0) {
         return (dividend / divisor); 
       }
       else { 
         return NAN;
       }
    }
    

    相关文章

      网友评论

          本文标题:代码组织

          本文链接:https://www.haomeiwen.com/subject/nbippttx.html