1 Object-C的類可以多重繼承么缎患?可以實現(xiàn)多個接口嗎抑胎?Category是什么古胆?重寫一個類的方式用繼承好還是分類好?為什么炼列?
Object-c的類不可以多重繼承;可以實現(xiàn)多個接口只搁,通過實現(xiàn)多個接口可以完成C++的多重繼承;Category是類別,一般情況用分類好俭尖,用Category去重寫類的方法氢惋,僅對本Category有效,不會影響到其他類與原有類的關系稽犁。
2 #import跟#include又什么區(qū)別焰望?@class呢,#import<>跟#import””又什么區(qū)別已亥?
import是Objective-C導入頭文件的關鍵字熊赖,#include是C/C++導入頭文件的關鍵字,使用#import頭文件會自動只導入一次,不會重復導入虑椎,相當于#include和#pragma once;@class告訴編譯器某個類的聲明震鹉,當執(zhí)行時俱笛,才去查看類的實現(xiàn)文件,可以解決頭文件的相互包含;#import<>用來包含系統(tǒng)的頭文件传趾,#import””用來包含用戶頭文件迎膜。
4 寫一個setter方法用于完成@property(nonatomic, strong)NSString name, 寫一個setter方法用于完成@property(nonatomic, copy)NSString name
- (void) setName:(NSString*) str
{
[str retain];
[name release];
name = str;
} - (void)setName:(NSString )str
{
id t = [str copy];
[name release];
name = t;
}
5 對于語句NSStringobj = [[NSData alloc] init]; obj在編譯時和運行時分別時什么類型的對象?
編譯時是NSString的類型;運行時是NSData類型的對象
6 常見的object-c的數(shù)據(jù)類型有那些, 和C的基本數(shù)據(jù)類型有什么區(qū)別?
object-c的數(shù)據(jù)類型有NSString浆兰,NSNumber磕仅,NSArray,NSMutableArray簸呈,NSData等等榕订,這些都是class,創(chuàng)建后便是對象蜕便,而C語言的基本數(shù)據(jù)類型int劫恒,只是一定字節(jié)的內(nèi)存空間,用于存放數(shù)值;NSInteger是基本數(shù)據(jù)類型轿腺,并不是NSNumber的子類兼贸,當然也不是NSObject的子類。NSInteger是基本數(shù)據(jù)類型Int或者Long的別名(NSInteger的定義typedef long NSInteger)吃溅,它的區(qū)別在于,NSInteger會根據(jù)系統(tǒng)是32位還是64位來決定是本身是int還是Long鸯檬。
7 什么是id類型决侈,id 聲明的對象有什么特性?
Id 聲明的對象具有運行時的特性,即可以指向任意類型的objcetive-c的對象;
8 Objective-C如何對內(nèi)存管理的,說說你的看法和解決方法喧务?
Objective-C的內(nèi)存管理主要有三種方式ARC(自動內(nèi)存計數(shù))赖歌、手動內(nèi)存計數(shù)、內(nèi)存池功茴。
1). (Garbage Collection)自動內(nèi)存計數(shù):這種方式和java類似庐冯,在你的程序的執(zhí)行過程中。始終有一個高人在背后準確地幫你收拾垃圾坎穿,你不用考慮它什么時候開始工作展父,怎樣工作。你只需要明白玲昧,我申請了一段內(nèi)存空間栖茉,當我不再使用從而這段內(nèi)存成為垃圾的時候,我就徹底的把它忘記掉孵延,反正那個高人會幫我收拾垃圾吕漂。遺憾的是,那個高人需要消耗一定的資源尘应,在攜帶設備里面惶凝,資源是緊俏商品所以iPhone不支持這個功能吼虎。所以“Garbage Collection”不是本入門指南的范圍,對“Garbage Collection”內(nèi)部機制感興趣的同學可以參考一些其他的資料苍鲜,不過說老實話“Garbage Collection”不大適合適初學者研究思灰。
解決: 通過alloc – initial方式創(chuàng)建的, 創(chuàng)建后引用計數(shù)+1, 此后每retain一次引用計數(shù)+1, 那么在程序中做相應次數(shù)的release就好了.
2). (Reference Counted)手動內(nèi)存計數(shù):就是說,從一段內(nèi)存被申請之后坡贺,就存在一個變量用于保存這段內(nèi)存被使用的次數(shù)官辈,我們暫時把它稱為計數(shù)器,當計數(shù)器變?yōu)?的時候遍坟,那么就是釋放這段內(nèi)存的時候拳亿。比如說,當在程序A里面一段內(nèi)存被成功申請完成之后愿伴,那么這個計數(shù)器就從0變成1(我們把這個過程叫做alloc)肺魁,然后程序B也需要使用這個內(nèi)存,那么計數(shù)器就從1變成了2(我們把這個過程叫做retain)隔节。緊接著程序A不再需要這段內(nèi)存了鹅经,那么程序A就把這個計數(shù)器減1(我們把這個過程叫做release);程序B也不再需要這段內(nèi)存的時候,那么也把計數(shù)器減1(這個過程還是release)怎诫。當系統(tǒng)(也就是Foundation)發(fā)現(xiàn)這個計數(shù)器變 成員了0瘾晃,那么就會調(diào)用內(nèi)存回收程序把這段內(nèi)存回收(我們把這個過程叫做dealloc)。順便提一句幻妓,如果沒有Foundation蹦误,那么維護計數(shù)器,釋放內(nèi)存等等工作需要你手工來完成肉津。
解決:一般是由類的靜態(tài)方法創(chuàng)建的, 函數(shù)名中不會出現(xiàn)alloc或init字樣, 如[NSString string]和[NSArray arrayWithObject:], 創(chuàng)建后引用計數(shù)+0, 在函數(shù)出棧后釋放, 即相當于一個棧上的局部變量. 當然也可以通過retain延長對象的生存期.
3). (NSAutoRealeasePool)內(nèi)存池:可以通過創(chuàng)建和釋放內(nèi)存池控制內(nèi)存申請和回收的時機.
解決:是由autorelease加入系統(tǒng)內(nèi)存池, 內(nèi)存池是可以嵌套的, 每個內(nèi)存池都需要有一個創(chuàng)建釋放對, 就像main函數(shù)中寫的一樣. 使用也很簡單, 比如[[[NSString alloc]initialWithFormat:@”Hey you!”] autorelease], 即將一個NSString對象加入到最內(nèi)層的系統(tǒng)內(nèi)存池, 當我們釋放這個內(nèi)存池時, 其中的對象都會被釋放
9 原子(atomic)跟非原子性(non-atomic)屬性有什么區(qū)別强胰?
1). atomic提供多線程安全。是防止在寫未完成的時候被另外一個線程讀取妹沙,造成數(shù)據(jù)錯誤
2). non-atomic:在自己管理內(nèi)存的環(huán)境中偶洋,解析的訪問器保留并自動釋放返回的值,如果指定了 nonatomic 距糖,那么訪問器只是簡單地返回這個值
10 看下面的程序,第一個NSLog會輸出什么?這時str的retainCount是多少?第二個和第三個呢?為什么
SMutableArray* ary = [[NSMutableArray array] retain];
NSString *str = [NSString stringWithFormat:@"test"];
[str retain];
[aryaddObject:str];
NSLog(@”%@%d”,str,[str retainCount]);
[str retain];
[str release];
[str release];
NSLog(@”%@%d”,str,[str retainCount]);
[aryremoveAllObjects];
NSLog(@”%@%d”,str,[str retainCount]);
str的retainCount創(chuàng)建+1玄窝,retain+1,加入數(shù)組自動+1 3
retain+1肾筐,release-1哆料,release-1 2
數(shù)組刪除所有對象,所有數(shù)組內(nèi)的對象自動-1 1
11 內(nèi)存管理的幾條原則時什么?按照默認法則.那些關鍵字生成的對象需要手動釋放?在和property結合的時候怎樣有效的避免內(nèi)存泄露?
誰申請吗铐,誰釋放
遵循Cocoa Touch的使用原則;
內(nèi)存管理主要要避免“過早釋放”和“內(nèi)存泄漏”东亦,對于“過早釋放”需要注意@property設置特性時,一定要用對特性關鍵字,對于“內(nèi)存泄漏”典阵,一定要申請了要負責釋放奋渔,要細心。
關鍵字alloc 或new 生成的對象需要手動釋放;
設置正確的property屬性壮啊,對于retain需要在合適的地方釋放嫉鲸,