国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > iOS > 正文

Objective-C編程中語句和變量的一些編寫規范建議

2020-07-26 03:23:28
字體:
來源:轉載
供稿:網友

語句
條件語句

條件語句體應該總被大括號包圍。只有一行代碼最好也加上,否則會帶來安全隱患。

復制代碼 代碼如下:

// 推薦
if (!error) {
    return success;
}

// 不推薦
if (!error)
    return success;

if (!error) return success;


尤達表達式(Yoda)

不要使用尤達表達式。(名字起源于星球大戰中尤達大師的講話方式,總是用倒裝的語序)

復制代碼 代碼如下:

// 推薦
if ([myValue isEqual:@42]) { ...

// 不推薦
if ([@42 isEqual:myValue]) { ...


nil和BOOL的檢查

一些人喜歡用這樣的方式來檢查nil:

復制代碼 代碼如下:

if (nil == myValue) { ...

這樣做可以避開少些一個"=“的錯誤,因為一旦少寫一個”=“,那么nil是不能被賦值的,編譯器會報錯。

但是前面提到,最好不要使用尤達表達式。所以更好的解決方法是用”!”來完成nil和BOOL的檢查。

復制代碼 代碼如下:

// 推薦
if (someObject) { ...
if (![someObject boolValue]) { ...
if (!someObject) { ...

// 不推薦
if (someObject == YES) { ... // Wrong
if (myRawValue == YES) { ... // Never do this.
if ([someObject boolValue] == NO) { ...


不要嵌套多個if語句

不要嵌套多個if語句,而是使用多個return來避免增加復雜度,并提高代碼可讀性。

也就是說,在一個方法中,重要的部分盡量不要放在if語句中,而是將”其它情況”放在if中。

復制代碼 代碼如下:

// 推薦
- (void)someMethod {
  if (![someOther boolValue]) {
      return;
  }

  //Do something important
}

// 不推薦
- (void)someMethod {
  if ([someOther boolValue]) {
    //Do something important
  }
}


復雜的表達式

當一個判斷條件很復雜時,應該將它們提取出來賦值給一個BOOL變量。

復制代碼 代碼如下:

BOOL nameContainsSwift  = [sessionName containsString:@"Swift"];
BOOL isCurrentYear      = [sessionDateCompontents year] == 2014;
BOOL isSwiftSession     = nameContainsSwift && isCurrentYear;

if (isSwiftSession) {
    // Do something very cool
}


三元運算符

三元運算符要保證可讀性。

復制代碼 代碼如下:

// 推薦
result = a > b ? x : y;

// 不推薦
result = a > b ? x = c > d ? c : d : y;


當三元運算符的第二個參數(if 分支)返回和條件語句中已經檢查的對象一樣的對象的時候,下面的表達方式更靈巧:
復制代碼 代碼如下:

// 推薦
result = object ? : [self createObject];

// 不推薦
result = object ? object : [self createObject];


錯誤處理

有些方法通通過參數返回 error 的引用,使用這樣的方法時應當檢查方法的返回值,而非 error 的引用。

復制代碼 代碼如下:

// 推薦
NSError *error = nil;
if (![self trySomethingWithError:&error]) {
    // Handle Error
}

switch語句中的case,如果只有一行代碼可以不必加上大括號,但是多行需要加上。
復制代碼 代碼如下:

switch (condition) {
    case 1:
        // ...
        break;
    case 2: {
        // ...
        // Multi-line example using braces
        break;
       }
    case 3:
        // ...
        break;
    default:
        // ...
        break;
}

枚舉類型

使用NS_ENUM()這個宏來定義枚舉,它有更強大的的類型檢查和代碼補全。

復制代碼 代碼如下:

typedef NS_ENUM(NSUInteger, ZOCMachineState) {
    ZOCMachineStateNone,
    ZOCMachineStateIdle,
    ZOCMachineStateRunning,
    ZOCMachineStatePaused
};

變量
盡量使用長的、描述性的方法和變量名。

復制代碼 代碼如下:

// 推薦
UIButton *settingsButton;

// 不推薦
UIButton *setBut;


常量應該以駝峰法命名,并以相關類名作為前綴。
復制代碼 代碼如下:

// 推薦
static const NSTimeInterval ZOCSignInViewControllerFadeOutAnimationDuration = 0.4;

// 不推薦
static const NSTimeInterval fadeOutTime = 0.4;


推薦使用常量來代替字符串字面值和數字。可以方便復用,快速修改。

常量應該用static聲明為靜態常量,而不要用#define,除非它明確作為宏來使用。

復制代碼 代碼如下:

// 推薦
static NSString * const ZOCCacheControllerDidClearCacheNotification = @"ZOCCacheControllerDidClearCacheNotification";

static const CGFloat ZOCImageThumbnailHeight = 50.0f;

// 不推薦
#define CompanyName @"Apple Inc."
#define magicNumber 42


常量如果需要暴露給外部,那么要在頭文件中以這樣的形式:
復制代碼 代碼如下:

extern NSString *const ZOCCacheControllerDidClearCacheNotification;

并在實現文件中為它賦值。

只有公有的常量才需要添加命名空間作為前綴。盡管實現文件中私有常量的命名可以遵循另外一種模式,你仍舊可以遵循這個規則。

方法名與方法類型(-/+符號)間應加上一個空格。

方法段間也應該以空格間隔。

參數前應該有一個描述性的關鍵詞。

盡可能少用”and”這個詞,它不應該用來闡明有多個參數。

復制代碼 代碼如下:

// 推薦
- (void)setExampleText:(NSString *)text image:(UIImage *)image;
- (void)sendAction:(SEL)aSelector to:(id)anObject forAllCells:(BOOL)flag;
- (id)viewWithTag:(NSInteger)tag;
- (instancetype)initWithWidth:(CGFloat)width height:(CGFloat)height;

// 不推薦
- (void)setT:(NSString *)text i:(UIImage *)image;
- (void)sendAction:(SEL)aSelector :(id)anObject :(BOOL)flag;
- (id)taggedView:(NSInteger)tag;
- (instancetype)initWithWidth:(CGFloat)width andHeight:(CGFloat)height;
- (instancetype)initWith:(int)width and:(int)height;  // Never do this.


使用字面值來創建不可變的NSString,NSDictionary,NSArray和NSNumber對象。

用這種方式,注意不要將nil放在NSArray和NSDictionary里,這樣會導致崩潰。

復制代碼 代碼如下:

NSArray *names = @[@"Brian", @"Matt", @"Chris", @"Alex", @"Steve", @"Paul"];
NSDictionary *productManagers = @{@"iPhone" : @"Kate", @"iPad" : @"Kamal", @"Mobile Web" : @"Bill"};
NSNumber *shouldUseLiterals = @YES;
NSNumber *buildingZIPCode = @10018;

不要這樣:
復制代碼 代碼如下:

NSArray *names = [NSArray arrayWithObjects:@"Brian", @"Matt", @"Chris", @"Alex", @"Steve", @"Paul", nil];
NSDictionary *productManagers = [NSDictionary dictionaryWithObjectsAndKeys: @"Kate", @"iPhone", @"Kamal", @"iPad", @"Bill", @"Mobile Web", nil];
NSNumber *shouldUseLiterals = [NSNumber numberWithBool:YES];
NSNumber *buildingZIPCode = [NSNumber numberWithInteger:10018];

避免這樣的方式創建可變數組:
復制代碼 代碼如下:

NSMutableArray *aMutableArray = [@[] mutableCopy];

這樣的方式,在效率和可讀性上都存在問題。

效率:一個不必要的不可變數組被創建后馬上被廢棄,并沒有必要。

可讀性:可讀性并不好。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 杭锦后旗| 罗田县| 东海县| 甘洛县| 花垣县| 龙游县| 徐州市| 丰顺县| 天全县| 鄂尔多斯市| 广元市| 仁怀市| 辰溪县| 雅安市| 龙南县| 浦城县| 德清县| 闻喜县| 莫力| 镇平县| 阿图什市| 榆林市| 雅安市| 呼伦贝尔市| 宜阳县| 北票市| 望城县| 子长县| 关岭| 临朐县| 海盐县| 满城县| 枞阳县| 尚志市| 马鞍山市| 清丰县| 北宁市| 福州市| 丰都县| 太湖县| 通化县|