您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關基于ios逆向過程中lldb調試技巧有哪些,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
假如你準備在模擬器里面運行這個,你可以在“(lldb)”提示的后面輸入下面的:
(lldb) po $eax
LLDB在xcode4.3或者之后的版本里面是默認的調試器。假如你正在使用老一點版本的xcode的話,你又GDB調試器。他們有一些基本的相同的命令,因此假如你的xcode使用的是“(gdb)”提示,而不是“(lldb)”提示的話,你也能夠更隨一起做,而沒有問題。
“po”命令是“print object”(打印對象)的簡寫。“$eax”是cup的一個寄存器。在一個異常的情況下,這個寄存器將會包含一個異常對象的指針。注意:$eax只會在模擬器里面工作,假如你在設備上調試,你將需要使用”$r0″寄存器。
例如,假如你輸入:
(lldb) po [$eax class]
你將會看像這樣的東西:
(id) $2 = 0x01446e84 NSException
這些數字不重要,但是很明顯的是你正在處理的NSException對象在這里。
你可以對這個對象調用任何方法。例如:
(lldb) po [$eax name]
這個將會輸出這個異常的名字,在這里是NSInvalidArgumentException,并且:
(lldb) po [$eax reason]
這個將會輸出錯誤消息:
(unsigned int) $4 = 114784400 Receiver () has no segue with identifier 'ModalSegue'
注意:當你僅僅使用了“po $eax”,這個命令將會對這個對象調用“description”方法和打印出來,在這個情況下,你也會得到錯誤的消息。
關于“基于ios逆向過程中lldb調試技巧有哪些”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。