swift debug技術(shù)

主要有兩個函數(shù)用于輸出的文本表示對象和變量,那就是 print( ) 和println( )。

  • println( )換行輸出;
  • 其他的函數(shù)還有 debugPrintln()和debugPrint();

下面的例子中給出了一些功能,可以用于高級調(diào)試。

e.g: println("Hello World!")

控制臺輸出:

Hello World!

e.g:

var temp:String = "This is a String "
println(temp)
debugPrintln(temp)

控制臺輸出:

This is a String
"This is a String"

要實現(xiàn)對某個進(jìn)行描述輸出,可以重寫debugDescription( )或者 description( )方法:

e.g: 
class ClassA: NSObject {
var name: String = "unknown"
override  var description: String {
    return "ClassA: \(name)"
}
}
var tempA: ClassA = ClassA()
print(tempA.description)
println(tempA)

控制臺輸出:

ClassA: unknown
ClassA: unknown

使用toDebugString( )和toString( ) 這兩個方法將返回的結(jié)果debugPrint并打印成一個字符串:

e.g:
var str: String = toString(tempA)
println(str)

控制臺輸出:

ClassA: unknown

precondition( )和preconditionFailure( )這兩個方法的使用:

e.g:
var value: String = ""    
if value.lengthOfBytesUsingEncoding(NSUTF8StringEncoding) == 0 {
preconditionFailure("value is empty")}

控制臺輸出:

fatal error: value is empty: file /Users/cramesh/Documents/My_Works/SwiftTutorial/SwiftTutorial/AppDelegate.swift, line 37

確定一個對象可以用unsafeAddressOf():

e.g: println(unsafeAddressOf(value))

控制臺輸出:

0x00007f8df251e480

輸出和方法名可以做一下處理:

var className =       NSStringFromClass(self.classForCoder) println(className)
var methodName = NSStringFromSelector(__FUNCTION__) 
println(methodName)
//或者
println(__FUNCTION__)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末寺枉,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子绷落,更是在濱河造成了極大的恐慌姥闪,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件砌烁,死亡現(xiàn)場離奇詭異筐喳,居然都是意外死亡,警方通過查閱死者的電腦和手機函喉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進(jìn)店門避归,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人管呵,你說我怎么就攤上這事梳毙。” “怎么了捐下?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵账锹,是天一觀的道長萌业。 經(jīng)常有香客問我,道長奸柬,這世上最難降的妖魔是什么生年? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮鸟缕,結(jié)果婚禮上晶框,老公的妹妹穿的比我還像新娘。我一直安慰自己懂从,他們只是感情好授段,可當(dāng)我...
    茶點故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著番甩,像睡著了一般侵贵。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上缘薛,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天窍育,我揣著相機與錄音,去河邊找鬼宴胧。 笑死漱抓,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的恕齐。 我是一名探鬼主播乞娄,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼显歧!你這毒婦竟也來了仪或?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤士骤,失蹤者是張志新(化名)和其女友劉穎范删,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體拷肌,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡到旦,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了巨缘。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片添忘。...
    茶點故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖带猴,靈堂內(nèi)的尸體忽然破棺而出昔汉,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布靶病,位于F島的核電站会通,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏娄周。R本人自食惡果不足惜涕侈,卻給世界環(huán)境...
    茶點故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望煤辨。 院中可真熱鬧裳涛,春花似錦、人聲如沸众辨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽鹃彻。三九已至郊闯,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蛛株,已是汗流浹背团赁。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留谨履,地道東北人欢摄。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像笋粟,于是被迫代替她去往敵國和親怀挠。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,472評論 2 348

推薦閱讀更多精彩內(nèi)容

  • SwiftDay011.MySwiftimport UIKitprintln("Hello Swift!")var...
    smile麗語閱讀 3,829評論 0 6
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理矗钟,服務(wù)發(fā)現(xiàn)唆香,斷路器嫌变,智...
    卡卡羅2017閱讀 134,629評論 18 139
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法吨艇,類相關(guān)的語法,內(nèi)部類的語法腾啥,繼承相關(guān)的語法东涡,異常的語法,線程的語...
    子非魚_t_閱讀 31,598評論 18 399
  • //Clojure入門教程: Clojure – Functional Programming for the J...
    葡萄喃喃囈語閱讀 3,629評論 0 7
  • 一個點贊放大的效果倘待,并且有爆炸粒子外射的感覺 此處分為三步實現(xiàn) 爆炸性動畫 button 的放大放小 具體使用(需...
    天空中的球閱讀 7,891評論 15 30