회원가입아이디/비번찾기
실시간 TV
홈으로
개발 중 에러 발생시 에러 내용 확인, 해결방법 [Android]
7년 전
스스로 에러 해결을 하기 위해서는 필수적인 내용이니, 반드시 읽어보기 바란다.

지식인이나 기타 커뮤니티 활동을 하다 보면 에러 관련 문의가 많이 올라온다.
그중에서는 에러 내용을 포함해서 질문하는 사람이 있고, 그렇지 않은 경우가 있는데,
후자같은 경우는 제3자가 봤을 때 해결 해 주기가 상당히 까다롭다.
소스코드만 덜렁 첨부해버리면 그걸 다 읽는것도 고역이고 그마저도 없다면 해결이 불가능할정도이다.

여기서는 왜 에러가 발생했는지, 발생한 지점이 어디인지, 어떻게 해결해야 하는지를 알아보겠다.

먼저 에러를 확인하기 위해서 몇가지 준비작업이 필요하다.

에러는 이클립스의 DDMS > LogCat 이라는 곳에서 확인이 가능하다.

DDMS를 활성화시키기 위해 다음과 같이 한다.

Window > Open Perspective > Other... 클릭




확인 하면



다음과 같이 나타난다.
LogCat 부분을 끌어서 Devices부분과 1:1 비율로 창을 조절해도 되고 본인 편한대로 설정한다. 중요한것은 LogCat영역이 넓어야 보기 편하다는것.

LogCat이 뭐냐하면 단말기에서 발생하는 정보들이 표시되는 영역이다. 터치,통화상태,인터넷연결상태, 사용자 임의 로그 등등 단말기의 모든 정보가 실시간으로 나타나기 때문에 위에처럼 All messages (no filters) 에서는 확인이 사실상 매우 힘들다.
그래서 아래처럼 fureun, AndroidRuntime, tester 등과 같은 테그를 설정하게 되는데,
이렇게 하면 사용자가 로그를 출력할 때 특정 테그를 입력하면, 해당 테그단위로 로그를 확인 할 수 있다.
ex ) Log.d("fureun", "파란글씨 로그출력"); , Log.e("tester", "빨간글씨 로그출력");

테그 에는 레벨별로 색깔이 구분되어 있는데(i,d,e,v,w) 이것까지 다루면 깊히 들어가서 복잡해질 수 있으니 따로 설명하진 않겠다. 그냥 Log. 뒤에 e를 넣으면 빨간색으로, d를 넣으면 파란색으로, i는 초록색, v는 검정색, w는 노란색으로 출력된다는것만 알아두자. 이후 테그 관련 포스팅으로 따로 찾아뵙겠다.

테그 등록은 로그캣부분의 초록색 십자가를 누르면 다음과 같은 창이 나타나는데,




사진과 같이 테그명을 입력하고 OK 해주면 등록할 수 있다.

여기서 주목할것은 AndroidRuntime 테그이다.
어플 실행중 예기치 못한 예외가 발생하여 어플이 죽어버리는 경우, 원인이 저 테그에 출력된다.

임의로 NullPointerException이 발생하도록 만들어 어플을 죽이게 되면, LogCat에 어떻게 나타나는지 알아보겠다.

String a = null;
Log.d("fureun", a);
이렇게 널값을 출력하려고 하면 에러가 발생하게 되는데 내용은 다음과 같다




FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.eerrortest/com.example.eerrortest.MainActivity}: java.lang.NullPointerException: println needs a message
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2072)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2097)
at android.app.ActivityThread.access$600(ActivityThread.java:137)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1203)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4885)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:557)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException: println needs a message
at android.util.Log.println_native(Native Method)
at android.util.Log.d(Log.java:138)
at com.example.eerrortest.MainActivity.onCreate(MainActivity.java:16)
at android.app.Activity.performCreate(Activity.java:5220)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1082)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2036)
... 11 more

중요한부분만 굵게 표시 해 봤다.
제일 먼저 확인해야할것이 바로 저기 Caused by: 부분이다. 말 그대로 왜 에러가 났는지 나타내는 부분으로,
내용을 보면 java.lang.NullPointerException 라고 나타 나 있다.
이걸 구글이나 네이버에 검색 해 보면, 널값을 출력하려 했기 때문에 발생하는 에러라는것을 알 수 있다.

그 다음으로 at com.example.eerrortest.MainActivity.onCreate(MainActivity.java:16) 부분이 보일것이다.
에러 로그에서 자신의 패키지명이 앞에 붙어있는 라인이 있을 경우, 그곳에서 에러가 발생한거라고 보면 되겠다.
실제 LogCat에서 위의 줄을 더블클릭 하게 되면 자동으로 에러가 발생한 라인으로 이동한다.
여기서는 MainActivity.java의 16번째 라인으로 이동하게 된다. 16번째 라인에는
Log.d("fureun", a); 소스가 있는 위치로, a에 널값이 들어있기 때문에 에러가 발생했다는것을 알게 되었다.

이렇게 에러를 확인하고 해결 할 수 있다.
자신이 위의 에러 로그를 해독 할 엄두가 나지 않는다면, 위와 같이 에러 로그를 복사해서 질문에 첨부만 하더라도
답변 주는사람들이 좀 더 쉽게 해결시켜 줄 수 있다.
물론 답변이 달릴 확률도 오를것이다.
추천추천 : 264 추천 목록
번호 제목
1,346
 윈도우 서버 2019 취약점 점검 보안
1,345
 윈도우 서버 2019 취약점 점검 보안 (windows server 2019)
1,344
 Windows 취약점진단 보안가이드라인
1,343
 Windows Admin Center를 통한 서버 관리
1,342
 윈도우 서버에서 실행되는 서비스 확인
1,341
 Chrome NET::ERR CERT REVOKED 해결방법
1,340
 cmd 명령어 (명령 프롬프트 명령어) 모음
1,339
 Windows10 특정 프로그램(OCS 2007 R2)에서 첨부파일 드래그앤드롭이 안 되는 현상
1,338
 윈도우 로그, 관리 이벤트 삭제
1,337
 클린 부팅
1,336
 Windows 구성 요소 저장소에서 파일 손상 검사
1,335
 Windows Defender 검사 기록 삭제하기
1,334
 간단한 윈도우 10 정품 인증 (크랙프로그램 필요없음)
1,333
 오류난 폴더 강제삭제 방법
1,332
 크롬에서 플래시 항상 허용하도록 설정하기 (레지스트리) reg 파일 만들기
1,331
 GPT 디스크를 MBR 디스크로 변환
1,330
 MBR 디스크를 GPT 디스크로 변환
1,329
 구글 검색을 200% 활용하게 해주는 검색 명령어 총정리
1,328
 [Jquery] jQuery로 우클릭 방지, 드래그 방지, 선택 방지 (IE10, 파이어폭스, 크롬 확인)
1,327
 php 사용자 접속IP, 브라우저정보, os정보, http, https 접속프로토콜 알아오기
1,326
 [PHP] IE 브라우저 접속 검출하기
1,325
 윈도우10 시스템 예약 파티션 확인 및 삭제
1,324
 윈도우10 복구 파티션 삭제 방법
1,323
 윈도우10 부팅지연 검은화면에서 몇분간 머무는 현상 해결방법
1,322
 삼성노트북 바이오스 진입이 불가능한 경우 바이오스 재설치와 NVRAM 초기화
1,321
 익스플로러(IE)의 구글 검색공급자 한글로 변경 방법
1,320
 윈도우 10 기본 앱 삭제 및 복구
1,319
 meta 태그 http-equiv 설정방법과 차이점
1,318
 구글(Google)검색에서 고급연산자를 이용하여 많은 정보를 얻는 방법
1,317
 프로그램 없이 하드디스크 복사 및 백업하기
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright ⓒ musictrot All rights reserved.