216 SIGSEGV
SEGV_ACCERR
SIGSEGV通常由操作系統(tǒng)生成泻肯,但是有適當(dāng)權(quán)限的用戶可以在需要時使用kill系統(tǒng)調(diào)用或kill命令(一個用戶級程序拇舀,或者一個shell內(nèi)建命令)
來向一個進程發(fā)送信號。
閃退場景一:recorder deleteRecording 之前 先判斷文件是否存在楼吃,否則會造成過度釋放,解決方法:
if ([[NSFileManager defaultManager] fileExistsAtPath:self.recorder.url.path]) {
if (![self.recorder deleteRecording])
NSLog(@"Failed to delete %@", self.recorder.url);
}
閃退場景二: delegate = nil 催束。
將XXViewContrller設(shè)置為delegate時澎现,當(dāng)頁面發(fā)生跳轉(zhuǎn)時,XXViewController的對象會被釋放押赊,這是代碼走到[_delegate callbackMethod],
便出現(xiàn)crash饺藤。解決方法有二:1.將@property (nonatomic ,assign) id <BLELibDelegate>delegate; 中 assign關(guān)鍵字改為weak。
2.在XXViewController的delloc方法中添加:xxx.delegate = nil;
實例:
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
cell.delegate=self;
}
cell內(nèi)部控件的點擊事件通過代理方式如此實現(xiàn)時就會導(dǎo)致這個崩潰。
補充:SIG 是信號名的通用前綴, SEGV 是 segmentation violation 的縮寫
在 POSIX 兼容的平臺上涕俗,SIGSEGV 是當(dāng)一個進程執(zhí)行了一個無效的內(nèi)存引用罗丰,或發(fā)生段錯誤時發(fā)送給它的信號。SIGSEGV 的符號常量在頭文件 signal.h
中定義再姑。因為在不同平臺上萌抵,信號數(shù)字可能變化,因此符號信號名被使用元镀。通常绍填,它是信號11。
對于不正確的內(nèi)存處理,如當(dāng)程序企圖訪問 CPU 無法定址的內(nèi)存區(qū)塊時,計算機程序可能拋出 SIGSEGV栖疑。操作系統(tǒng)可能使用信號棧向一個處于自然狀態(tài)的應(yīng)用
程序通告錯誤讨永,由此,開發(fā)者可以使用它來調(diào)試程序或處理錯誤遇革。
在一個程序接收到 SIGSEGV 時的默認動作是異常終止住闯。這個動作也許會結(jié)束進程,但是可能生成一個核心文件以幫助調(diào)試澳淑,或者執(zhí)行一些其他特定于某些平臺
的動作比原。
SIGSEGV可以被捕獲。也就是說杠巡,應(yīng)用程序可以請求它們想要的動作量窘,以替代默認發(fā)生的動作。這樣的動作可以是忽略它氢拥、調(diào)用一個函數(shù)蚌铜,或恢復(fù)默認的動作。
在一些情形下嫩海,忽略 SIGSEGV 導(dǎo)致未定義行為冬殃。
一個應(yīng)用程序可能處理SIGSEGV的例子是調(diào)試器,它可能檢查信號棧并通知開發(fā)者目前所發(fā)生的叁怪,以及程序終止的位置审葬。
tableView滑動刪除,返回導(dǎo)致程序崩潰問題
- (void)tableView:(UITableView*)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyleforRowAtIndexPath:(NSIndexPath *)indexPath;
實現(xiàn)后奕谭,刪除某個cell沒有問題涣觉,但滑動一行但不選中delete按鈕,就點擊導(dǎo)航欄的返回按鈕血柳,出現(xiàn)了崩潰現(xiàn)象官册,而且崩潰是出現(xiàn)在跳回到之前的界面之后,崩潰之后提示打印出EXE_BAD_ACESSS錯难捌,
直接到了 main 函數(shù)里膝宁。問題可能是在 canEditRowAtIndexPath 這個方法里設(shè)置了YES然后返回的時候沒有把它設(shè)置成 NO 所以報錯鸦难,ios6會自動設(shè)置成NO,iOS7 就手動設(shè)置成 NO也可以员淫。
方案一:viewWillDisappear手動設(shè)置 editing 這個屬性為NO 解決合蔽。參考:http://blog.csdn.net/damon2989/article/details/44410367
-(void)viewWillDisappear:(BOOL)animated{
[super viewWillDisappear:animated];
[self.tableView setEditing:NO];
}
方案二:在刪除事件點擊完成時reloadData也可以
- (NSArray *)tableView:(UITableView *)tableView editActionsForRowAtIndexPath:(NSIndexPath *)indexPath{
//添加一個刪除按鈕
UITableViewRowAction *deleteAction = [UITableViewRowAction rowActionWithStyle:(UITableViewRowActionStyleDestructive) title:@"刪除" handler:^(UITableViewRowAction *action, NSIndexPath *indexPath) {
[tableView reloadData];
NSLog(@"****:delete");
}];
deleteAction.backgroundColor = [UIColor redColor];
//將設(shè)置好的按鈕方到數(shù)組中返回
return @[deleteAction];
}
3.UIVisualEffectView報錯的問題:
Assertion failure in -[UIVisualEffectView _addSubview:positioned:relativeTo:],
/BuildRoot/Library/Caches/com.apple.xbs/Sources/UIKit_Sim/UIKit-3698.21.8/UIVisualEffectView.m:1464
(lldb)
添加全局斷點找到錯誤所在:
[self.effectview addSubview:label]
UIVisualEffectView添加子View的方式不對,在ios 11上必須添加到它的contentView內(nèi):
[self.effectview.contentView addSubview: label];