1. 遠(yuǎn)程debug調(diào)試java代碼
目前創(chuàng)新互聯(lián)已為1000多家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬主機(jī)、網(wǎng)站托管運(yùn)營(yíng)、企業(yè)網(wǎng)站設(shè)計(jì)、綏寧網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶(hù)導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶(hù)和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。
1.1 主動(dòng)連接調(diào)試
首先需要遠(yuǎn)程服務(wù)配置啟動(dòng)腳本:
JAVA_OPTS="$JAVA_OPTS -Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=8000"
如果是啟動(dòng)jar包,指令:
java -Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=8000 -jar test.jar
這里-Xdebug是通知JVM工作在DEBUG模式下,-Xrunjdwp是通知JVM使用(java debug wire protocol)來(lái)運(yùn)行調(diào)試環(huán)境。
transport是監(jiān)聽(tīng)Socket端口連接方式(也可以dt_shmem共享內(nèi)存方式,但限于windows機(jī)器,并且服務(wù)提供端和調(diào)試端只能位于同一臺(tái)機(jī))。
server=y表示當(dāng)前是調(diào)試服務(wù)端,=n表示當(dāng)前是調(diào)試客戶(hù)端。suspend=n表示啟動(dòng)時(shí)不中斷(如果啟動(dòng)時(shí)中斷,一般用于調(diào)試啟動(dòng)不了的問(wèn)題)。
address=8000表示本地監(jiān)聽(tīng)8000端口。
遠(yuǎn)程服務(wù)(tomcat/jboss)啟動(dòng)成功后,本地Eclipse對(duì)需要調(diào)試的地方打上斷點(diǎn),
然后項(xiàng)目右鍵啟動(dòng)遠(yuǎn)程調(diào)試:Debug as-Debug Configurations-Remote Java Application。
Host為遠(yuǎn)程主機(jī)IP,Port為遠(yuǎn)程監(jiān)聽(tīng)調(diào)試端口,Connection Type為:Standard(Socket Attach),
點(diǎn)擊Debug,然后打斷點(diǎn),遠(yuǎn)程服務(wù)運(yùn)行到斷點(diǎn)處本地就會(huì)中斷,然后進(jìn)行調(diào)試。
1.2 被動(dòng)連接調(diào)試
首先需要Eclipse配置監(jiān)聽(tīng),如主動(dòng)連接調(diào)試的Eclipse配置圖片,Connection Type選擇:
Standard(Socket Listen),配置本地監(jiān)聽(tīng)端口,比如默認(rèn)8000。點(diǎn)擊Debug開(kāi)始等待遠(yuǎn)程連接調(diào)試。
然后配置遠(yuǎn)程服務(wù)啟動(dòng)腳本:
JAVA_OPTS="$JAVA_OPTS -Xdebug -Xrunjdwp:transport=dt_socket,address=127.0.0.1:8000,suspend=y"
如果是調(diào)試jar包,指令:
java -Xdebug -Xrunjdwp:transport=dt_socket,address=127.0.0.1:8000,suspend=y -jar remoting-debug.jar
參數(shù)含義和主動(dòng)連接調(diào)試一樣,只是這里suspend=y表示啟動(dòng)時(shí)就中斷,需要連接本地IDE調(diào)試啟動(dòng)。
address=ip:port,ip需要修改為本地的對(duì)外IP。
這樣遠(yuǎn)程項(xiàng)目啟動(dòng)時(shí)就連接到本地,方便調(diào)試項(xiàng)目啟動(dòng)不了的問(wèn)題。
步驟:
1、在cmd中切換到編寫(xiě)的代碼所保存的目錄下;
2、在cmd中輸入javac然后點(diǎn)空格,再點(diǎn)擊文件名和包括后綴名確定后,在存放編寫(xiě)代碼的文件下會(huì)生成一個(gè)class的字節(jié)碼文件;
3、在cmd中輸入java然后點(diǎn)空格,輸入第二步中生成的字節(jié)碼的文件名,不需要后綴名,點(diǎn)擊確定即可運(yùn)行代碼。
代碼就是程序員用開(kāi)發(fā)工具所支持的語(yǔ)言寫(xiě)出來(lái)的源文件,是一組由字符、符號(hào)或信號(hào)碼元以離散形式表示信息的明確的規(guī)則體系。計(jì)算機(jī)代碼稱(chēng)為源代碼,是相對(duì)目標(biāo)代碼和可執(zhí)行代碼而言的。 源代碼就是用匯編語(yǔ)言和高級(jí)語(yǔ)言寫(xiě)出來(lái)的地代碼,目標(biāo)代碼是指源代碼經(jīng)過(guò)編譯程序產(chǎn)生的能被cpu直接識(shí)別二進(jìn)制代碼。
1、以一個(gè)1到100求累加和的小程序?yàn)槔M(jìn)行說(shuō)明。程序代碼,第一步,雙擊各行左側(cè)對(duì)應(yīng)區(qū)域添加斷點(diǎn)。
2、根據(jù)程序代碼,設(shè)置預(yù)期的端點(diǎn),設(shè)置完畢后,左側(cè)會(huì)出現(xiàn)圖標(biāo)作為標(biāo)記。
3、在代碼窗口任意位置右擊鼠標(biāo),先選擇Debug As,再選擇Java Application進(jìn)入調(diào)試界面。
4、調(diào)試界面,點(diǎn)擊左上方窗口上的綠色三角箭頭按鈕開(kāi)始調(diào)試,每點(diǎn)擊一下,程序運(yùn)行一步,即從開(kāi)始運(yùn)行到第一個(gè)斷點(diǎn),在從第一個(gè)斷點(diǎn)到第二個(gè),依次進(jìn)行。
5、右上方窗口顯示每一步運(yùn)行后變量的值,可與預(yù)期結(jié)果進(jìn)行比較,以便修改。左上方的紅色按鈕是終止調(diào)試鍵,按此可結(jié)束調(diào)試。圖中所示是程序運(yùn)行幾步后的情況。
6、調(diào)試結(jié)束返回Java編碼窗口。點(diǎn)擊右上方表格形按鈕,選擇Java選項(xiàng),即返回Java編碼窗口,。
最基本的操作是:
1, 首先在一個(gè)java文件中設(shè)斷點(diǎn),然后運(yùn)行,當(dāng)程序走到斷點(diǎn)處就會(huì)轉(zhuǎn)到debug視圖下,
2, F5鍵與F6鍵均為單步調(diào)試,F(xiàn)5是step into,也就是進(jìn)入本行代碼中執(zhí)行,F(xiàn)6是step over,
也就是執(zhí)行本行代碼,跳到下一行,
3,F7是跳出函數(shù)
4,F8是執(zhí)行到最后。
1.Step Into (also F5) 跳入
2.Step Over (also F6) 跳過(guò)
3.Step Return (also F7) 執(zhí)行完當(dāng)前method,然后return跳出此method
4.step Filter 逐步過(guò)濾 一直執(zhí)行直到遇到未經(jīng)過(guò)濾的位置或斷點(diǎn)(設(shè)置Filter:window-preferences-java-Debug-step Filtering)
5.resume 重新開(kāi)始執(zhí)行debug,一直運(yùn)行直到遇到breakpoint
6.hit count 設(shè)置執(zhí)行次數(shù) 適合程序中的for循環(huán)(設(shè)置 breakpoint view-右鍵hit count)
7.inspect 檢查 運(yùn)算。執(zhí)行一個(gè)表達(dá)式顯示執(zhí)行值
8.watch 實(shí)時(shí)地監(jiān)視變量的變化
9.我們常說(shuō)的斷點(diǎn)(breakpoints)是指line breakpoints,除了line
breakpoints,還有其他的斷點(diǎn)類(lèi)型:field(watchpoint)breakpoint,method
breakpoint,exception breakpoint.
10.field breakpoint 也叫watchpoint(監(jiān)視點(diǎn)) 當(dāng)成員變量被讀取或修改時(shí)暫掛
11.添加method breakpoint 進(jìn)入/離開(kāi)此方法時(shí)暫掛(Run-method breakpoint)
12.添加Exception breakpoint 捕抓到Execption時(shí)暫掛(待續(xù)...)斷點(diǎn)屬性:
1.hit count 執(zhí)行多少次數(shù)后暫掛 用于循環(huán)
2.enable condition 遇到符合你輸入條件(為ture\改變時(shí))就暫掛
3.suspend thread 多線程時(shí)暫掛此線程
4.suspend VM 暫掛虛擬機(jī)
13.variables 視圖里的變量可以改變變量值,在variables 視圖選擇變量點(diǎn)擊右鍵--change value.一次來(lái)進(jìn)行快速調(diào)試。
14.debug 過(guò)程中修改了某些code后--〉savebuild--resume--重新暫掛于斷點(diǎn)
1.debug。斷點(diǎn)調(diào)試。
2.輸出消息。system.out.println();來(lái)調(diào)試。
3.動(dòng)態(tài)代理(Dynamic
Proxy)。動(dòng)態(tài)代理是一個(gè)特定的Java特性,它允許開(kāi)發(fā)者引入proxy類(lèi),加進(jìn)某一給定類(lèi)之前,并通過(guò)某一給定接口截獲所有調(diào)用。你可以在很短時(shí)間內(nèi)用一個(gè)普通代理設(shè)置一個(gè)虛擬事件處理器,來(lái)查看事件發(fā)生順序。當(dāng)需要理解事件處理器時(shí)這是最簡(jiǎn)單和快捷的方法。
4.運(yùn)行時(shí)剖析器(Run-time
Profiler)。剖析器是通過(guò)特定的JVM
hooks在系統(tǒng)中跟蹤所有調(diào)用的強(qiáng)大工具。但是用它來(lái)跟蹤執(zhí)行過(guò)程是大才小用。
5.Aspects。面向方面編程。它是截獲你的代碼執(zhí)行既快速又容易的方法。你可以圍繞方法、構(gòu)造器、屬性訪問(wèn)等等有選擇地設(shè)置hook,而不需要修改原始代碼。在這些hook中,你可以打印調(diào)試消息。
1.2常用的。3.4.5網(wǎng)上找的。
文章名稱(chēng):代碼調(diào)試java 代碼調(diào)試的過(guò)程是什么?
文章位置:http://jinyejixie.com/article32/hpcdpc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、網(wǎng)站策劃、定制開(kāi)發(fā)、標(biāo)簽優(yōu)化、微信公眾號(hào)、域名注冊(cè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)