중단점 걸기
우선 확인하고 싶은 라인에 중단점을 걸어 앱 실행을 일시 중지합니다. 중단점을 거는 방법은 라인 옆의 빈공간을 클릭 하거나 단축키 (Command+F8 / Control+F8)를 클릭합니다. 아래 이미지의 라인 옆의 빨간 점이 중단점입니다.
data:image/s3,"s3://crabby-images/2bb24/2bb245487effa3c9c87370d864cd1c8fdcf53456" alt="01"
앱이 실행 중일 때
오른쪽 상단의 Attach debugger to Android process를 클릭해 디버깅 모드를 실행할 수 있습니다.
data:image/s3,"s3://crabby-images/f09b7/f09b713ebf87bd32f88d41b60512caee9c0b1e67" alt="02"
앱이 실행 중이지 않을 때
Debug ‘app’ 버튼 또는 단축키(^D)를 클릭해 디버깅 모드를 실행합니다.
data:image/s3,"s3://crabby-images/d1efe/d1efe54e8caee674be07dc2e3d59f2d70adb3c5a" alt="03"
앱이 실행되다가 단점을 만나면 아래와 같이 앱은 일시중지될 겁니다.
data:image/s3,"s3://crabby-images/438d7/438d7b4989b52a079eff60c2fa238f39dd6b7a10" alt="04"
이때 디버깅 탭의 도구들을 사용해서 앱의 상태를 확인할 수 있습니다.
data:image/s3,"s3://crabby-images/429f2/429f20d5f9be5096d48a75700fc6ef04522f9e8e" alt="05"
만약 Variables 영역이 보이지 않으면, 1번 영역에서 Restore Variables View를 클릭합니다. 이 영역은 변수의 객체 트리를 확인할 수 있습니다.
data:image/s3,"s3://crabby-images/aca8d/aca8da0f190bf0afd3db41de1528adc4ccfcacfe" alt="06"
변수 위에 마우스 커서를 올리면 Variables 영역을 보지 않고도 변수를 확인할 수 있습니다. + 를 누르면 더 자세한 객체 트리도 확인할 수 있습니다. 객체는 왼쪽의 화살표를 누르면 객체에 속한 필드도 확인할 수 있습니다.
data:image/s3,"s3://crabby-images/b3ca3/b3ca3da94dffd2a8d97b15dd5348f3d07ef0e49f" alt="07"
data:image/s3,"s3://crabby-images/d1a28/d1a280346cdb590957f0ab54814cc49bb534150d" alt="08"
2번 영역은 현재 어느 메서드에 멈춰있는지 알려줍니다. main에서 시작해 run, invoke… onCreateView에 일시중지한 것을 보여줍니다.
data:image/s3,"s3://crabby-images/8cf33/8cf33a7ba376a60e2594c53c46d1858a0881fc4d" alt="09"
1번 영역의 Restore Watches View를 클릭하면 아래 화면이 보입니다.
data:image/s3,"s3://crabby-images/e2291/e22912a59138cd7c02155b992feaa2da02791833" alt="10"
Watches는 break 된 상태에서 코드를 실행할 수 있는 창입니다. 모든 코드를 사용할 수 있는 것은 아니고 현재 라인에서 사용 가능한 코드만 쓸 수 있습니다. + 버튼을 눌러 확인하고 싶은 코드를 입력하면 결과를 바로 확인할 수 있습니다.
data:image/s3,"s3://crabby-images/d2f46/d2f467d69bc6a7523a34cef04b58f4a60f2a9ff6" alt="11"
아래 이미지는 디버깅 탭입니다. 각 버튼의 기능을 알아볼까요?
data:image/s3,"s3://crabby-images/9daab/9daab44ae4f2672b3630074d7a30a0baf5fd6291" alt="12"
중단점을 만나 일시중지된 상태에서 Step Over 버튼을 클릭해 다음 줄로 이동합시다.
data:image/s3,"s3://crabby-images/68b3a/68b3a1ad39ea2f39f9734394c91004e9193239bd" alt="13"
Step Into 버튼을 클릭해 getContents() 메서드의 첫 라인으로 이동합니다.
data:image/s3,"s3://crabby-images/8f3f4/8f3f4eee332a97b0946c58122bfbe870ebb0eded" alt="14"
Step Out 버튼을 클릭해 getContents() 메서드 밖의 다음 줄로 이동합니다.
data:image/s3,"s3://crabby-images/ccf0f/ccf0f378c16a43970376f1668d900182ddd37bc6" alt="15"
Step Over 버튼을 눌러 코드의 다음 줄로 이동합니다.
data:image/s3,"s3://crabby-images/b955b/b955b69a1a6241515d2ca10f85128dfe648346f1" alt="16"
data:image/s3,"s3://crabby-images/c5cf7/c5cf78937b86836085ea79755123916a286407d2" alt="17"
'Android > Android관련 이것 저것..' 카테고리의 다른 글
AppBundle 알아보기 (2) | 2019.09.05 |
---|---|
안드로이드 스튜디오 단축키 (2) | 2019.03.10 |
안드로이드 타이틀바와, 스테이터스바 없애기( FULL SCREEN) ,WindowManager (2) | 2019.02.04 |
안드로이드 multidex 문제 해결하기 (2) | 2019.02.01 |
안드로이드 앱런처 만들기 (4) | 2019.01.29 |
댓글