<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    yxhxj2006

    常用鏈接

    統(tǒng)計(jì)

    最新評(píng)論

    Eclipse Debug不為人知的秘密

    Debug視圖

    認(rèn)識(shí)debug視圖,紅色部分框?yàn)榫€程堆棧視圖,黃色部分框?yàn)楸磉_(dá)式、斷點(diǎn)、變量視圖,藍(lán)色部分為代碼視圖。



     線程堆棧視圖

    分別介紹一下這幾個(gè)按鈕的含義:

    1.表示當(dāng)前實(shí)現(xiàn)繼續(xù)運(yùn)行直到下一個(gè)斷點(diǎn),快捷鍵為F8。

    2.表示打斷整個(gè)進(jìn)程

    3.表示進(jìn)入當(dāng)前方法,快捷鍵為F5。

    4.表示運(yùn)行下一行代碼,快捷鍵為F6。

    5.表示退出當(dāng)前方法,返回到調(diào)用層,快捷鍵為F7。

    6.表示當(dāng)前線程的堆棧,從中可以看出在運(yùn)行哪些代碼,并且整個(gè)調(diào)用過(guò)程,以及代碼行號(hào)



     

    變量視圖

    1.為變量名視圖,顯示當(dāng)前代碼行中所有可以訪問(wèn)的實(shí)例變量和局部變量

    2.顯示所有的變量值

    3.可以通過(guò)該窗口來(lái)改變變量值



     

    斷點(diǎn)視圖

    1.顯示所有斷點(diǎn)

    2. 將當(dāng)前窗口1中選中的端口失效,再次點(diǎn)擊啟用。

    3.異常斷點(diǎn)



     

    表達(dá)式視圖

    表達(dá)式視圖:表達(dá)式視圖是Debug過(guò)程中較為常用的一個(gè)視圖,可以對(duì)自己的感興趣的一些變量進(jìn)行觀察,也可以增加一些自己的表達(dá)式,也可以查看一行代碼的運(yùn)行結(jié)果。

    1.表達(dá)式

    2. 點(diǎn)擊此可以新增一個(gè)表達(dá)式



     

    代碼視圖

    代碼視圖:用來(lái)顯示具體的代碼。其中綠色部分是指當(dāng)前將要執(zhí)行的代碼



     

     

    場(chǎng)景一:小明辛苦了兩天終于將自己的負(fù)責(zé)的任務(wù)完成了,第二天轉(zhuǎn)測(cè)后,測(cè)試找到了小明說(shuō),小明的程序有bug,可以是小明經(jīng)過(guò)仔細(xì)調(diào)試,發(fā)現(xiàn)本地沒(méi)有任何問(wèn)題,但是測(cè)試的環(huán)境上確實(shí)有問(wèn)題,所以小明遇到了難題,測(cè)試的環(huán)境linux,又不能上去linux去debug,小明這個(gè)時(shí)候想要是Linux也可以debug就好了.

    遠(yuǎn)程debug

    遠(yuǎn)程debug:遠(yuǎn)程debug顧名思義,能夠?qū)⑦h(yuǎn)程操作系統(tǒng)上的任何java進(jìn)行debug,但是有前提是本地需要有同步的代碼。

    1.遠(yuǎn)程debug的步驟是在遠(yuǎn)程操作系統(tǒng)上啟動(dòng)java進(jìn)程時(shí)增加特殊的

    -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,address=$DEBUG_PORT,server=y,suspend=n

    2.在Eclipse中新建一個(gè)Remote Java Application

    遠(yuǎn)程debug

    1.打開(kāi)Debug Configurations視圖

    2.右擊Remote Java Application,

    New

    3.選擇源碼工程

    4.輸入遠(yuǎn)程IP和端口,端口即服務(wù)

    端的$DEBUG_PORT,點(diǎn)擊OK。




     
     

     

    場(chǎng)景一:小明寫了一個(gè)任務(wù)執(zhí)行者,該執(zhí)行者不間斷的執(zhí)行一些任務(wù),在現(xiàn)網(wǎng)上運(yùn)行了一段時(shí)間后,發(fā)現(xiàn)有概率的出現(xiàn)一些故障,發(fā)現(xiàn)運(yùn)行一段時(shí)間后,該任務(wù)者異常退出了,退出的因?yàn)槭强罩羔槪梢孕∶飨胍诒镜豥ebug,不知道斷點(diǎn)打在哪里,該問(wèn)題是概率事件,不一定會(huì)出現(xiàn),所以小明debug幾遍下來(lái)后,頭暈眼花,連代碼都看不清楚了,小明想要是能有個(gè)斷點(diǎn)每當(dāng)出現(xiàn)空指針異常的時(shí)候就停下來(lái)讓他發(fā)現(xiàn)問(wèn)題,那該多好呀。

    異常斷點(diǎn)

    異常斷點(diǎn):在定位問(wèn)題的過(guò)程中,常常會(huì)遇到斷點(diǎn)無(wú)法打到合適的位置,以至于和問(wèn)題的觸發(fā)點(diǎn)千差萬(wàn)別,所以這個(gè)時(shí)候不妨試試異常斷點(diǎn),顧名思義,異常斷點(diǎn)是指拋出某種異常后自動(dòng)掛起的斷點(diǎn)。

    點(diǎn)擊紅色部位,增加一個(gè)異常斷點(diǎn)



     

    輸入想要定位的異常類型,例如NullPointerException,這樣系統(tǒng)中拋出任何NullPointerException異常后,都會(huì)掛起當(dāng)前線程,給你機(jī)會(huì)去定位問(wèn)題。

     

    場(chǎng)景一:小明寫了一個(gè)巨大的循環(huán),在調(diào)測(cè)代碼時(shí),小明發(fā)現(xiàn)每當(dāng)循環(huán)到第100000次的時(shí)候,就是出現(xiàn)問(wèn)題,沒(méi)有達(dá)到自己的預(yù)期,于是小明在循環(huán)里打了個(gè)斷點(diǎn),想看看到底怎么回事,可小明萬(wàn)萬(wàn)沒(méi)有想到,想要到達(dá)100000次循環(huán)是多么的困難,小明這個(gè)時(shí)候已經(jīng)開(kāi)始浮想聯(lián)翩,如果能有這樣的斷點(diǎn):

                 If 循環(huán)次數(shù)== 100000,線程停下來(lái)

    條件斷點(diǎn)

    如右圖,循環(huán)1000次,如果想要在循環(huán)到500

    次的時(shí)候停下來(lái),可以創(chuàng)建一個(gè)條件斷點(diǎn),右

    擊斷點(diǎn)懸著B(niǎo)reakpoint Properties。



     

    選中Enable Condition

    在空白處,添加你自己的條件,如果條件返回true,線程會(huì)被掛起,如果為false,則忽略該異常

    Hit Count為該斷點(diǎn)經(jīng)過(guò)多少次后,正式掛起線程,如果設(shè)置為500,則表達(dá)前499次,經(jīng)過(guò)該斷點(diǎn)都不會(huì)停下,當(dāng)?shù)?00次,該斷點(diǎn)會(huì)掛起當(dāng)前線程。

     

     

    表達(dá)式

    表達(dá)式可以查看一些在當(dāng)前代碼中沒(méi)有的命令行,方便定位問(wèn)題。

     

    場(chǎng)景一:小明最近遇到一個(gè)難題,在調(diào)用一個(gè)第三方插件時(shí)總是會(huì)有問(wèn)題,小明懷疑是第三方插件的bug,但小明沒(méi)有找到源碼不能進(jìn)行debug,小明該怎么辦呢?

    Debug定位第三方插件的問(wèn)題

    1.使用反編譯工具將代碼反編譯

    2.將反編譯后的源碼進(jìn)行過(guò)濾

    3.修復(fù)源碼編譯錯(cuò)誤

    4.進(jìn)行debug

    Debug一些經(jīng)驗(yàn)

    1.盡量減少debug,少用debug,優(yōu)秀的程序員總是花80%的時(shí)間來(lái)思考如何解決問(wèn)題,20%的時(shí)間來(lái)動(dòng)手完成代碼,而糟糕的程序員總是用20%的時(shí)間去寫代碼,80%的時(shí)間去調(diào)試代碼,動(dòng)手之前盡量想好如何去做,并且已經(jīng)為你自己的思路做了充分的實(shí)驗(yàn)。

    2.盡可能的提高debug的效率,設(shè)置合適的斷點(diǎn),使用快捷鍵。

    3.debug的F6快捷鍵經(jīng)常用到,它與金山詞霸的快捷鍵沖突,所以在debug的時(shí)候最好將金山詞霸關(guān)掉。

    4.debug的表達(dá)式是可執(zhí)行代碼,將會(huì)對(duì)代碼結(jié)果產(chǎn)生永久性影響,在調(diào)試時(shí)注意,經(jīng)常將不用的表達(dá)式清除掉。

    posted on 2012-08-30 18:16 奮斗成就男人 閱讀(2870) 評(píng)論(0)  編輯  收藏 所屬分類: java

    主站蜘蛛池模板: 久久国产亚洲精品麻豆| 亚洲免费在线视频观看| 亚洲一级特黄大片在线观看 | 久久久久无码专区亚洲av| 国产亚洲国产bv网站在线| jyzzjyzz国产免费观看| 亚洲av无码国产精品色午夜字幕| eeuss影院ss奇兵免费com| 337p日本欧洲亚洲大胆精品555588 | 免费一级毛片在级播放| 2020国产精品亚洲综合网| 亚洲精品在线视频| 国产高潮久久免费观看| 亚洲经典在线观看| 久久精品国产影库免费看| 亚洲AV成人影视在线观看| 99久久精品毛片免费播放| 野花高清在线观看免费完整版中文| 亚洲国产综合91精品麻豆| 香港a毛片免费观看 | 全免费A级毛片免费看网站| 国产永久免费高清在线| 久久久亚洲精品国产| 国产成人在线观看免费网站| 久久精品视频免费播放| 天堂亚洲免费视频| 国产中文在线亚洲精品官网| 特级做A爰片毛片免费69| 亚洲AV无码成人网站在线观看| 啦啦啦完整版免费视频在线观看 | 久久精品免费一区二区三区| 在线亚洲午夜片AV大片| 久久夜色精品国产嚕嚕亚洲av| 免费女人高潮流视频在线观看| 亚洲av无码久久忘忧草| 亚洲AV无码国产丝袜在线观看 | 国产精品无码免费视频二三区 | 免费精品一区二区三区第35| 日日摸夜夜添夜夜免费视频| 亚洲欧洲免费无码| 亚洲一卡二卡三卡|