15,用前綴避免命名空間沖突
1安拟, 選擇自己的公司蛤吓,應(yīng)用程序或者二者皆有關(guān)聯(lián)之名稱作為類名的前綴糠赦,并在所有代碼中均使用這一前綴。
2淌山, 如果自己所開發(fā)的程序庫中用到了第三方庫艾岂,則應(yīng)為其中的名稱加上前綴朋其。
整個項目添加前綴
16氓辣,提供'全能初始化方法'
1钞啸,在類中提供一個全能的初始化方法喇潘,并在文檔中說明,其他初始化方法均應(yīng)調(diào)用此方法
2絮吵,若全能初始化方法與超類不同蹬敲,則需要覆寫超類中的對應(yīng)方法
3,如果超類的初始化方法不適用子類伴嗡,那么應(yīng)該覆寫這個超類方法瘪校,并在其中拋出異常
OC中需要在調(diào)用 ?[super init] 后設(shè)置本類的初始化屬性
Swift中需要在首先設(shè)置本類的初始化屬性后,再調(diào)用父類的初始化方法
17赏寇,實(shí)現(xiàn)descrition方法
1嗅定, 實(shí)現(xiàn)descriton方法用踩,并返回一個有意義的字符串脐彩,用以描述該實(shí)例
2, 若想在調(diào)試時打印更詳盡的描述信息梅誓,則應(yīng)該實(shí)現(xiàn) debugDescription方法
#import
static char*constPROPERTIESLIST ="PROPERTIESLIST";
- (NSString*)description
{
NSArray* arrPropertys = objc_getAssociatedObject(self, PROPERTIESLIST);
if(!arrPropertys) {
arrPropertys = [self filterPropertys];
}
NSArray*arrValue = [self propertyValues:arrPropertys];
NSMutableString*reuslt = [NSMutableString new];
[reuslt appendString:[super description]];
[reuslt appendString:@"\n"];
for(inti =0; i < arrPropertys.count; i++) {
NSString*strProperty = arrPropertys[i];
id property = arrValue[i];
[reuslt appendFormat:@"%@ ----> %@\n", strProperty, property];
}
return reuslt;
}
- (NSArray*)propertyValues:(NSArray*)arrPropertys {
NSMutableArray*values = [NSMutableArray array];
for(NSString*columnName in arrPropertys) {
id value = [self valueForKey:columnName];
if(value !=nil) {
[values addObject:value];
}else{
[values addObject:[NSNullnull]];
}
}
return values;
}
- (NSArray*)filterPropertys
{
NSMutableArray*props = [NSMutableArray array];
unsignedintoutCount, i;
objc_property_t*properties =class_copyPropertyList([self class], &outCount);
for(i =0; i<outCount; i++)
{
const char* char_f =property_getName(properties[i]);
NSString*propertyName = [NSString stringWithUTF8String:char_f];
[props addObject:propertyName];
}
objc_setAssociatedObject(self,PROPERTIESLIST, props,OBJC_ASSOCIATION_RETAIN_NONATOMIC);
free(properties);
returnprops;
}
- (void)dealloc
{
//NSLog(@"%@已銷毀", [self class]);
}
18,盡量使用不可變對象
1嗅回,盡量創(chuàng)建不可變的對象
2,若某屬性僅可于對象內(nèi)部修改埂陆,則可在 ?分類中將其由 readonly 屬性擴(kuò)展為 readwrite屬性
3焚虱,不要把可變的collection作為屬性公開懂版,而應(yīng)提供相關(guān)的方法定续,以此修改對象的可變collection
在.h 中聲明
@property(nonatomic,strong,readonly )NSArray* arrTest;
-(void)setArrTest:(NSArray*)arrTest;
在.m 分類中
@property(nonatomic,strong,readwrite) NSArray* arrTest;
-(void)setArrTest:(NSArray*)arrTest{
_arrTest= arrTest;
}
19,使用清晰而協(xié)調(diào)的命名方式
1摹察,起名時供嚎,應(yīng)遵從標(biāo)準(zhǔn)的oc命名規(guī)范峭状,這樣創(chuàng)建出來的接口更容易為其他開發(fā)者所理解
2,方法名要言簡意賅劝赔,從左到右讀起來要像個日常用語中的句子才好
3胆敞,方法名里不要使用縮略后的類型名稱
4,給方法起名時的第一要務(wù)就是確保其風(fēng)格與自己的代碼所繼承的框架相符
20仍翰,為私有方法加前綴
1观话,給私有方法的名稱加上前綴,這樣可以很容易的和共同公共方法區(qū)分開
2灵迫, 不要單用一個下劃線做私有方法的前綴龟再,因?yàn)檫@種做法是預(yù)留給蘋果公司用的
例如:p_
21, 理解oc 的錯誤模型
1尼变,只有發(fā)生了可使這個應(yīng)用程序崩潰的嚴(yán)重錯誤時,才應(yīng)使用異常
2哀澈,在錯誤不那么嚴(yán)重的情況下度气,可以指派 ‘委托方法’來出來錯誤,可可以把錯誤信息放進(jìn)NSError對象里适荣,經(jīng)由‘輸出參數(shù)’返回給調(diào)用者
22,理解NSCopying協(xié)議
1弛矛, 若想另自己所寫的對象具有拷貝功能丈氓,則需要實(shí)現(xiàn)NSCopying協(xié)議
2, 如果自定義的對象分為可變版本與不可變版本湾笛,那么就要同事實(shí)現(xiàn)NSCopying 和 NSMutableCopying協(xié)議
3闰歪, 賦值對象時需要采用淺拷貝 還是深拷貝,一般情況下應(yīng)盡量使用淺拷貝
4嘉赎, 如果你所寫的對象需要支持深拷貝公条,那么可考慮新增一個專門執(zhí)行深拷貝的方法