IT_Programming/Dev Tools

이클립스 디버깅 1

JJun ™ 2010. 1. 18. 18:45
 

-----------------------------------------------------------------------------------

          참고 출처 : Tong - icircle님의 프로그램통 / http://darkkaiser.cafe24.com/blog/105

-----------------------------------------------------------------------------------

 

[이클립스 디버그 방법]


1. 톰켓서버를 먼저 실행


2. 라인에 더블클릭하면 파란 동그라미 생긴다. 여기서 부터 디버그를 하겠다는 표시


3. 웹어플사이트에 액션을 수행하면 창이 뜨고 확인 누르면된다.
    그러면 디버그 모드로 간다


4. F6은 한줄씩디버그 하기

   오른쪽 위에 variable 과 병행하면서 코드를 본다.


5. F5는 안에 있는 메소드로 들어가고 싶을때 사용.
    그리고 들어가면 다시 F6으로 한줄씩 디버깅체크


6. F7은 중도에 다시 돌아가고 싶을 때

    F8은 한번에 검사하고 싶은곳을 같이 보고싶을 때


7. 한가지 변수에만 검사하고싶다.

    블럭해서 오른쪽 마우스클릭 후 watch 선택

 

-------------------------------------------------------------------------------------------------

 

[이클립스 디버깅 고급편]

 

 

 

Display
Display 뷰에는 현재 스택 프레임의 컨텍스트에서 실행할 수 있는 모든 종류의 수식을 입력하고 실행할 수

있다. 현재 컨텍스트에서 볼 수 없는 변수나 메서드를 사용하거나 문법적으로 잘못된 수식을 평가하려고 하면

에러가 표시된다.

특정 컨텍스트에서 수식을 실행시켜 결과를 확인하고 싶을 때 사용
 
 

 

 

 


Inspect

Display 뷰에는 확인하고 싶은 수식을 마음대로 입력할 수 있는 장점이 있지만, 수식의 평가 결과가

문자열로만 표시되는 단점이 있다. 수식의 평가 결과가 객체일 경우에는 해당 객체가 toString() 메서드를

이용해 문자열로 변환된 결과만을 보여주므로 불편하다.

수식 평가의 결과로 나온 객체를 좀더 자세히 확인하고 싶다면 Inspect 기능을 이용할 수 있다.

에디터에서 수식을 선택한 다음 컨텍스트 메뉴에서 Inspect를 선택(또는 Ctrl+Shift+I)하면

아래 그림과 같이 해당 수식의 평가 결과가 팝업에 표시된다.

 

 

이 상태에서 Ctrl+Shift+I 키를 한번 더 누르면 팝업의 내용이 expression!s 뷰로 이동한다.
 

 


특정 컨텍스트에서 코드 실행 결과가 객체로 리턴되는 경우 객체의 내부를 자세히 살펴보는 데 사용

 

 


Watch

어떤 경우에는, 프로그램을 한 스텝씩 진행할 때마다 어떤 수식으 결과를 지속적으로 평가하며 추적하고

싶을 것이다. 매번 Inspect/Display 기능을 쓰며 변수 값을 추적하는 것은 매우 번거로운 작업일 수 있다.

이럴 때는 Watch 기능을 이용할 수 있다. 해당 수식이 이미 변수에 저장되어 사용되고 있다면 그 변수를 Variables 뷰에서 확인해도 충분하지만, 변수에 대입되지 않은 수식이나, 복잡한 수식 중 일부분의 값이

어떻게 변하는지 추적하고 싶을 때는 Watch 기능을 사용할 수 밖에 없다. Watch는 특정 수식을 스텝이

진행될 때마다 매번 다시 평가하여 expression!s 뷰에 표시하는 기능이다. 에디터에서 추적할 수식을

선택한 다음 컨텍스트 메뉴에서 Watch를 선택하면 아래 그림고 같이 Expressins 뷰에 Watch 항목이

추가된다. 수식 "(l+u)/2"가 Watch 되고 있는 항목인데, 바로 위에 있는 Inspect 항목과 아이콘이 다르므로

쉽게 구분할 수 있다. 
 


expression!s 뷰에서 컨텍스트 메뉴를 띄워 Add Watch expression!을 선택하면 아래 그림과 같은 다이얼로그가 뜨는데 여기에 수식을 입력해 Watch 항목을 추가할 수 있다. 또한 Inspect로 이미 등록된 항목을 선택한 다음 컨텍스트 메뉴에서 Convert to Watch expression!을 선택해 Inspect 항목을 Watch 항목으로 바꿀 수도 있다. 
 

 

 

코드의 실행에 따라 지속적으로 변하는 수식으 값을 추적하는 데 사용

 


 

논리적 구조 보기(logical structure)

EmployeeList 객체에 있는 직원 리스트를 확인하기 위해 list 필드를 expression!s 뷰에 Inspect 항목으로

추가해 보자. list 필드는 java.util.Vector 타입이고 expression!s 뷰에서 트리를 펼치면 아래 그림과 같은

형식으로 보일 것이다. 
 


그런데 우리가 Vector나 Map 등의 컬렉션 객체를 expression!s 뷰에서 보려는 경우는 그 내부 구조를

모두 보고 싶은 경우 보다는 컬렉션 객체가 포함하고 있는 객체를 보고 싶은 경우가 많을 것이다.

이럴 때 논리적 구조 보기를 이용하면 해당 객체를 좀더 컴팩트하고 의미있는 형태로 볼 수 있다.

뷰 툴바에 있는 Show Logical Structure 버튼을 누르면 아래 그림과 같이 Vector 내부에 있는

다른 속성은 사라지고 우리가 관심있는 Vector가 포함하고 있는 객체의 목록만 표시된다. 
 

 

-------------------------------------------------------------------------------------------------

 


[이클립스 자주쓰는 단축키 및 기술]


 Code Assist :  Ctrl + Space (자동으로 이클립스 코드 보여주는 기능)

 Quick Fix : Ctrl + 1 (에러시 빨간에러표시시 Ctrl + 1 을 누르면 방법 제시)

 Quick Hierarchy : Ctrl + T (계층 구조 보기)
 
 Quick Outline : Ctrl + O (아웃라인구조 보기)

 Source Code Navigation : F3, Alt + Forward

 라인 앞, 뒤 이동하기:  Alt + Forward (→), Alt + Back (←)

 

 클래스나 메소드를 들어가 보고싶을 때 (ctrl을 누르고 클릭해도가능) :

 Line move : Ctrl + L (라인 이동)
 
 Mark Occurrences : 형광등 기능. 관련된 것에 같은색으로 표시됨.

 Search : Ctrl + F (소스내 검색기능)
              Ctrl + H (파일이나 자바나 플러그인 등 검색시)

 Comment : Ctrl + /   ( // 블럭 지정하여 자동으로 주석 처리하기)

                  Ctrl + Shift + / (/**/ 주석), Ctrl + Shift + \ (해제)

 Import! : Ctrl + Shift + O (import!!!! 에러시 필요한 정보를 제시하여준다)

-------------------------------------------------------------------------------------------------