除非確有必要,否則不要引入頭文件。一般來說,應在某個類的頭文件中使用向前聲明來提及別的類,并在實現文件中引入那些類的頭文件。這樣做可以盡量降低類之間的耦合(coupling)。
有時無法使用向前聲明(@class 類名)(.h文件在某個類引入類對象,.m實現#import類名),比如要聲明某個類遵循一項協議。這種情況下,盡量把“該類遵循某協議”的這條聲明移至“class-continuation分類”中。如果不行的話,就把協議單獨放在一個頭文件中,然后將其引入。
Note:@class與#import的區別
1.import會包含這個類的所有信息,包括實體變量和方法,而@class只是告訴編譯器,其后面聲明的名稱是類的名稱,至于這些類是如何定義的,暫時不用考慮,后面會再告訴你。
2.在頭文件中, 一般只需要知道被引用的類的名稱就可以了。 不需要知道其內部的實體變量和方法,所以在頭文件中一般使用@class來聲明這個名稱是類的名稱。 而在實現類里面,因為會用到這個引用類的內部的實體變量和方法,所以需要使用#import來包含這個被引用類的頭文件。
3.在編譯效率方面考慮,如果你有100個頭文件都#import了同一個頭文件,或者這些文件是依次引用的,如A–>B, B–>C, C–>D這樣的引用關系。當最開始的那個頭文件有變化的話,后面所有引用它的類都需要重新編譯,如果你的類有很多的話,這將耗費大量的時間。而是用 @class則不會。
4.如果有循環依賴關系,如:A–>B, B–>A這樣的相互依賴關系,如果使用#import來相互包含,那么就會出現編譯錯誤,如果使用@class在兩個類的頭文件中相互聲明,則不會有編譯錯誤出現。
所以,一般來說,@class是放在interface中的,只是為了在interface中引用這個類,把這個類作為一個類型來用的。 在實現這個接口的實現類中,如果需要引用這個類的實體變量或者方法之類的,還是需要import在@class中聲明的類進來.
從Objective-C 1.0起,有一種非常簡單的方式能創建NSString、NSNumber、NSArray、NSDictionary這樣的對象。這就是“字符串字面量”(string literal),其語法如下:
NSString *someString = @"Effective Objective-C 2.0"; NSNumber *intNumber = @1; NSNumber *floatNumber = @2.5f; NSNumber *doubleNumber = @3.14159; NSNumber *boolNumber = @YES; NSNumber *charNumber = @'a'; int x = 5; float y = 6.32f; NSNumber *exPRessionNumber = @(x * y); //效果等于是先創建了一個數組,然后把方括號內的所有對象都加到這個數組中 NSArray *animals = @[@"cat", @"dog", @"mouse", @"badger"]; NSString *dog = animals[1]; NSDictionary *personData = @{@"firstName" : @"Matt", @"lastName" : @"Galloway", @"age" : @28}; NSString *lastName = personData[@"lastName"]; mutableArray[1] = @"dog"; mutableDictionary[@"lastName"] = @"Galloway"; //局限性-------使用字面量語法創建出來的字符串、數組、字典對象都是不可變的(immutable)。若想要可變版本的對象,則需復制一份: NSMutableArray *mutable = [@[@1, @2, @3, @4, @5]mutableCopy];
新聞熱點
疑難解答