Swift學習_自定義Log&異常捕捉

Swift

1.自定義Log

// 1.獲取打印所在的文件(例如:ViewController.swift)
// lastPathComponent:獲取最后一個路徑
let file = (#file as NSString).lastPathComponent
    
// 2.獲取打印所在的方法(例如:viewDidLoad())
let funcName = #function
    
// 3.獲取打印所在行數(shù)(例如22)
let lineNum = #line

要想在Swift中使用DEBUG,需要在Build Settings中設(shè)置一些東西,如下圖:


設(shè)置DEBUG
將以下代碼寫在AppDelegate.swift中,寫成全局函數(shù),就可以在其他地方調(diào)用了
// T是動態(tài)類型
func SHLog<T>(message: T,file:String = #file,funcName:String = #function,lineNum:Int = #line){
    
    #if DEBUG       // Build Settings --> swift flags --> 在debug后點擊+ --> -D 自己起的名字
    
    let fileName = (file as NSString).lastPathComponent
    
    print("\(fileName):(第\(lineNum)行) - \(message)")
    //        print("\(fileName):[\(funcName)](\(lineNum)) - \(message)")   // 會打印函數(shù)名
    
    #endif
}

2.Swift中異常處理

如果在調(diào)用系統(tǒng)某一個方法時,該方法最后有一個throws,說明該方法會拋出異常,那么需要對該異常進行處理

Swift中提供了三種處理異常的方式
1.try方式 程序員手動捕捉異常
let pattern = "abc"
do{
    let regex = try NSRegularExpression(pattern: pattern, options: .caseInsensitive)
}catch{
    catch:捕捉異常
    error:異常的對象
    print(error)
}
2.try?方式 系統(tǒng)幫助我們處理異常,如果該方法出現(xiàn)了異常,則該方法返回nil;如果沒有異常,則返回對應(yīng)的對象
let pattern = "abc"
guard let regex = try? NSRegularExpression(pattern: pattern, options: .caseInsensitive) else{
    return
}
3.try!方式(不建議,非常危險) 直接告訴系統(tǒng),該方法沒有異常。注意:如果該方法出現(xiàn)了異常,那么程序會報錯(崩潰)
let pattern = "abc"
let regex = try! NSRegularExpression(pattern: pattern, options: .caseInsensitive)

}


代碼已上傳至git:
--> 傳送門:Swift_基本語法

附錄

查看完整專欄《Swift學習》

有問題歡迎指正以及相互探討 —— CoderSun

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 15,264評論 4 61
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,553評論 19 139
  • 01 告離段落 一年一度的校優(yōu)秀系組評審工作終于結(jié)束,S作為此次評審組長終于可以長長舒一口氣了。接下來就是等待最終...
    付琴貓小魚閱讀 484評論 0 0
  • 平時對自己的要求比較高,想讓自己多看看一些書籍,多學習知識,但是很多比如歷史的,初看有興趣,可是時間一長,我就忍受...
    向天葵閱讀 313評論 0 0
  • 使用startActivityForResult()啟動Activity時: 不能添加Intent.FLAG_AC...
    樂此不痞閱讀 131評論 0 0

友情鏈接更多精彩內(nèi)容