[Android Studio 權威教程]斷點調試和進階調試
有人說Android 的調試是最坑的,那我只能說是你不會用而已,我可以說Android Studio的調試是我見過最棒的。
好了開始寫一個簡單的偵錯工具,我們先來一個for迴圈
for (int i = 0; i < 10; i++) {//擷取當前i的值 int selector = i; //打log查看當前i的值(此步多餘,實際開發請忽略) Logger.e("for當前的i的值:" + i); //調用方法 stepNext(i);}
設定斷點(點擊紅點位置添加或取消斷點)
點擊debug模式運行
查看調試面板
一、簡單調試1. step over:一步步往下走
當前程式啟動並執行位置,我們看到i的值已經在程式碼中展示出來了,黃色的代碼處,這個是AS的功能,對於我們調試來講,這簡直是非常大的福利了。
點擊單步調試按鈕或按快速鍵F8,看看效果。這裡我們看到selector變數的值已經出來了selector:0,我們在看看黃色位置i的當前值是0。
這時我們繼續F8,我們切換到logcat查看日誌,我列印出的i的值是0,
我們在切回道Debugger面板,可以看到Variables顯示面板中,有i的值是0,selector的值是0。以及我們可以看到Frames控制台中可以顯示出當前程式的位置在:onCreate():28,第28行。
2. step into:看到方法往裡走
比如我們的for迴圈當中調用了一個stepNext(int i)方法,當我們走到這裡想看看這個方法裡面的運行過程的時候我們可以這樣,當走到這個方法的時候我們可以按下F7,或者如的表徵圖。
這時就走到了stepNext方法當中。
在這裡列印了一個log,我們再按一下F8我們來看看Logcat, 這裡我列印的log都是為了做教程用,調試我們就不用打log了直接看顯示面板就OK了
3. force step into :所有方法看完整
這個是可以看到你所調用的所有方法的實現會讓你跟著它走一遍,研究源碼使用非常方便
4. step out :有斷點下一個,走完斷點繼續走
這裡如果我們的一個流程當中,包括調用的方法,如果有斷點走到下一個斷點,如果沒有斷點,而是在一個調用的方法當中,會跳出這個方法,繼續走。
vc/E0aOsvtm49sD919OjujxiciAvPg0KPGltZyBhbHQ9"這裡寫圖片描述" src="http://www.bkjia.com/uploads/allimg/150618/041AB956-13.png" title="\" />
()我現在程式位置在第一個斷點位置(24行),我調用的stepNext方法中也有一個斷點,此時我按下step out按鈕會走到stepNext中的斷點處(39行)我此時如果再按一下step out 會走到stepNext方法的調用出的下一個可執行代碼(30行)
()如果我現在程式位置在stepNext的方法中,如果我此時按下step out,會走到stepNext方法的調用出的下一個可執行代碼(30行)
5. run to Cursor :下個斷點我們見
這裡的意思就是說,會很快執行到下一個斷點的位置,而且可以靜如任何調用的方法
二、進階調試1. 跨斷點調試
如果我們設定了多個斷點,現在我們需要直接跳轉到下一個斷點,那麼直接點擊就可以了
2.觀察變數
如果我們想觀察1個或者幾個變數的值的變化,如果我們在Variables顯示面版中觀察如果我這裡有太多太多的自訂變數和系統變數了,那麼就難觀察了,我們可以做如下操作:
點擊Watches,點擊+號,然後輸入變數的名稱斷行符號就OK了,而且會有記錄哦
如果變數名比較長我們可以這樣:
選擇[Variables]中的變數名然後點擊[右鍵],選擇[Add to Watches],然後Watches面板中就有了
3.設定變數的值
在程式中有很多的條件陳述式和迴圈語句,調試也是比較耗時的,我們可以通過快速設定變數的值來加快調試速度,我們可以做如下操作:
選擇[Variables]中的變數名然後點擊[右鍵],選擇[Set Value..]或者選擇之後直接F2(如)(為Variables面板)
4.查看斷點
點擊之後我們可以看到所有的斷點,以及位置代碼,也可以設定一些屬性
5.停止調試
要注意的是這裡的[停止調試]不是讓程式停止,而是跳過所有調試
到這裡我們的Android Studio的斷點調試和進階調試就完畢了。
有興趣的童鞋可以關注我的Blog,我的專欄會持續更新Android Studio 教程,以及2015 I/O大會上的NDK的配置和編譯,我也全部會分享給大家。
並且我收到了CSND 的講師邀請,後期我會把這些Android Studio的使用教程錄製成視頻發布在CSDN學院。
/** * -------------- * 歡迎轉載 | 轉載請註明 * -------------- * 如果對你有協助,請點擊|頂| * -------------- * 請保持謙遜 | 你會走的更遠 * -------------- * @author zsl * @github https://github.com/yy1300326388 * @blog http://blog.csdn.net/yy1300326388 */