안드로이드 디버깅 방법
잡았다, 오류!
김보예
2018-06-14
디버깅(Debugging)은 오류가 발생했을 때 발생 위치를 확인할 수 있는 방법입니다. 앱이 일시 중지된 상태에서 변수를 검사하고 식을 평가해 런타임 오류 원인을 판별할 수 있죠.
중단점 걸기
우선 확인하고 싶은 라인에 중단점을 걸어 앱 실행을 일시 중지합니다. 중단점을 거는 방법은 라인 옆의 빈공간을 클릭 하거나 단축키 (Command+F8 / Control+F8)를 클릭합니다. 아래 이미지의 라인 옆의 빨간 점이 중단점입니다.
data:image/s3,"s3://crabby-images/75e88/75e88f2e3784432ca644d0dc2b3660a25a9df275" alt="01"
앱이 실행 중일 때
오른쪽 상단의 Attach debugger to Android process를 클릭해 디버깅 모드를 실행할 수 있습니다.
data:image/s3,"s3://crabby-images/f0662/f06628fadf4186dd6a13b34d0934d1e53a5fa680" alt="02"
앱이 실행 중이지 않을 때
Debug ‘app’ 버튼 또는 단축키(^D)를 클릭해 디버깅 모드를 실행합니다.
data:image/s3,"s3://crabby-images/1295e/1295e5f8337ab75cb4e5c2633854a651435a3ca9" alt="03"
앱이 실행되다가 단점을 만나면 아래와 같이 앱은 일시중지될 겁니다.
data:image/s3,"s3://crabby-images/71ab5/71ab55cb8932cd867f237b5e44c2a467f8cc7390" alt="04"
이때 디버깅 탭의 도구들을 사용해서 앱의 상태를 확인할 수 있습니다.
data:image/s3,"s3://crabby-images/a8c59/a8c59048c0d69c0a07b456d32dea564620886a2a" alt="05"
만약 Variables 영역이 보이지 않으면, 1번 영역에서 Restore Variables View를 클릭합니다. 이 영역은 변수의 객체 트리를 확인할 수 있습니다.
data:image/s3,"s3://crabby-images/109aa/109aa0ddb313ab981e3aa4520a5de698cf4fe51c" alt="06"
변수 위에 마우스 커서를 올리면 Variables 영역을 보지 않고도 변수를 확인할 수 있습니다. + 를 누르면 더 자세한 객체 트리도 확인할 수 있습니다. 객체는 왼쪽의 화살표를 누르면 객체에 속한 필드도 확인할 수 있습니다.
data:image/s3,"s3://crabby-images/9dd3d/9dd3dceda378091f1250b6c6cd94770063503a56" alt="07"
data:image/s3,"s3://crabby-images/72409/72409cecc1668422feb3a02571479bd17394fe76" alt="08"
2번 영역은 현재 어느 메서드에 멈춰있는지 알려줍니다. main에서 시작해 run, invoke… onCreateView에 일시중지한 것을 보여줍니다.
data:image/s3,"s3://crabby-images/b6b4d/b6b4dacf9b91f475c8bd249a35a719a5e9eb59c3" alt="09"
1번 영역의 Restore Watches View를 클릭하면 아래 화면이 보입니다.
data:image/s3,"s3://crabby-images/d6460/d646041b74b5eb8b4e1e9c999af17899ad73eaea" alt="10"
Watches는 break 된 상태에서 코드를 실행할 수 있는 창입니다. 모든 코드를 사용할 수 있는 것은 아니고 현재 라인에서 사용 가능한 코드만 쓸 수 있습니다. + 버튼을 눌러 확인하고 싶은 코드를 입력하면 결과를 바로 확인할 수 있습니다.
data:image/s3,"s3://crabby-images/91381/913812191c468b1fd365e50b421c7c63f19d83a7" alt="11"
아래 이미지는 디버깅 탭입니다. 각 버튼의 기능을 알아볼까요?
data:image/s3,"s3://crabby-images/6a7fc/6a7fcf9128ef27f476a6428102aeb6548554661f" alt="12"
중단점을 만나 일시중지된 상태에서 Step Over 버튼을 클릭해 다음 줄로 이동합시다.
data:image/s3,"s3://crabby-images/951f1/951f1af6afb0a6e17a00e71ded8c44384aee3cde" alt="13"
Step Into 버튼을 클릭해 getContents() 메서드의 첫 라인으로 이동합니다.
data:image/s3,"s3://crabby-images/63128/6312822c18cc4eb7cb4c99622eb4b95b0b5af391" alt="14"
Step Out 버튼을 클릭해 getContents() 메서드 밖의 다음 줄로 이동합니다.
data:image/s3,"s3://crabby-images/c8d78/c8d786e60c12d97d8d75fdd0f68ead66ff378cc7" alt="15"
Step Over 버튼을 눌러 코드의 다음 줄로 이동합니다.
data:image/s3,"s3://crabby-images/f89a5/f89a5983287b1f7ce212efecd512148ee19bffb6" alt="16"
data:image/s3,"s3://crabby-images/8e831/8e831642e32b03ed20b0eec3ad1b4dc89118963d" alt="17"
지금까지 안드로이드 디버깅 방법을 알아봤습니다. 기능이 많아서 처음부터 다 활용할 순 없겠지만 계속 기능을 사용하다 보면 점점 익숙해지지 않을까요?