最近遇到這樣一個問題,以前的時候并未注意;新建一個工程,然后添加一個類,文件結構是這樣的
創(chuàng)新互聯為客戶提供專業(yè)的網站設計、成都網站制作、程序、域名、空間一條龍服務,提供基于WEB的系統(tǒng)開發(fā). 服務項目涵蓋了網頁設計、網站程序開發(fā)、WEB系統(tǒng)開發(fā)、微信二次開發(fā)、成都做手機網站等網站方面業(yè)務。然后寫了這樣一小段程序,運行
- (void)viewDidLoad { [super viewDidLoad]; Test *testObj = [[Test alloc] init]; NSLog(@"release 前 %d",[testObj retainCount]); [testObj release]; NSLog(@"release 后 %d",[testObj retainCount]); }
明明release了,retainCount計數應該為0,但是 為什么retainCount計數還是1,當我們release操作兩次的時候程序就崩潰了;
然后我們打印一下testObj對象
- (void)viewDidLoad { [super viewDidLoad]; Test *testObj = [[Test alloc] init]; NSLog(@"release 前 %d",[testObj retainCount]); NSLog(@"testObj release指向-->%@",testObj); [testObj release]; NSLog(@"release 后 %d",[testObj retainCount]); NSLog(@"testObj release指向-->%@",testObj); }
發(fā)現他們指向同一塊地址;
testObj 在alloc的時候在堆上申請到一片空間,然后它的retainCount計數為1,然后我們release之后,testObj指向的空間被銷毀了,不存在了。此時testObj就是一個野指針了;此時我們調用[testObj retainCount]就屬于一個不安全的做法;
然后我們在添加一行代碼,[testObj release]之后,添加 testObj = nil;
- (void)viewDidLoad { [super viewDidLoad]; Test *testObj = [[Test alloc] init]; NSLog(@"release 前 %d",[testObj retainCount]); NSLog(@"testObj release指向-->%@",testObj); [testObj release]; testObj = nil; NSLog(@"release 后 %d",[testObj retainCount]); NSLog(@"testObj release指向-->%@",testObj); }
唉,看到這里就應該明白了吧,[testObj release] 后,testObj仍有指向,只是testObj原來指向的那片空間已被銷毀,但是本身還存在,通過置為nil這一步操作,就不在指向原來那片地址;應該記起viewDidUnload函數作用了吧,它就是干這個活的,我們申明一個對象屬性的時候,在viewDidUnload中將這個屬性置為nil這一步操作;
另外有需要云服務器可以了解下創(chuàng)新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。