App(Java, Kotlin)에서 Call Stack을 출력하는 방법을 소개합니다.
Java
Log
를 이용하여 다음과 같이 Call Stack을 출력할 수 있습니다.
Log.d(TAG, "Call stack", new Throwable("get stacks"));
Ouput:
09-28 22:10:14.289 15580 15580 D MainActivity: call stack
09-28 22:10:14.289 15580 15580 D MainActivity: java.lang.Throwable: get stacks
09-28 22:10:14.289 15580 15580 D MainActivity: at com.example.myapplication.MainActivity.onCreate(MainActivity.java:16)
09-28 22:10:14.289 15580 15580 D MainActivity: at android.app.Activity.performCreate(Activity.java:7802)
09-28 22:10:14.289 15580 15580 D MainActivity: at android.app.Activity.performCreate(Activity.java:7791)
09-28 22:10:14.289 15580 15580 D MainActivity: at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1299)
위와 유사하게 wtf
로그로 간단하게 Call stack을 출력하는 코드를 작성할 수 있습니다.
Log.wtf(TAG, new Throwable("get stacks"));
try-catch
를 사용하는 경우, Exception이 발생할 때 Call stack을 출력하면 디버깅에 도움이 될 수 있습니다.
다음과 같이 Call stack을 출력하도록 할 수 있습니다. 예제 코드를 소개하기 위해 throw new Exception()
으로 Exception이 발생하도록 했습니다.
try {
throw new Exception("get stacks");
} catch(Exception e) {
e.printStackTrace();
}
Log
를 이용하는 코드와 차이점은 TAG를 지정할 수 없어 System.err
TAG로 출력된다는 것입니다.
09-28 22:13:43.165 15875 15875 W System.err: java.lang.Exception: get stacks
09-28 22:13:43.166 15875 15875 W System.err: at com.example.myapplication.MainActivity.onCreate(MainActivity.java:18)
09-28 22:13:43.166 15875 15875 W System.err: at android.app.Activity.performCreate(Activity.java:7802)
09-28 22:13:43.166 15875 15875 W System.err: at android.app.Activity.performCreate(Activity.java:7791)
09-28 22:13:43.166 15875 15875 W System.err: at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1299)
다음과 같이 구현하면 TAG를 지정하면서 Call stack을 출력할 수 있습니다.
try {
throw new Exception("get stacks");
} catch(Exception e) {
Log.d(TAG, Log.getStackTraceString(e));
}
Output:
09-28 22:15:27.982 15980 15980 D MainActivity: java.lang.Exception: get stacks
09-28 22:15:27.982 15980 15980 D MainActivity: at com.example.myapplication.MainActivity.onCreate(MainActivity.java:18)
09-28 22:15:27.982 15980 15980 D MainActivity: at android.app.Activity.performCreate(Activity.java:7802)
09-28 22:15:27.982 15980 15980 D MainActivity: at android.app.Activity.performCreate(Activity.java:7791)
09-28 22:15:27.982 15980 15980 D MainActivity: at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1299)
다음과 같이 단독으로 사용할 수 있습니다. 앞에서 소개한 방법과 유사합니다.
Log.d(TAG, Log.getStackTraceString(new Exception("get stacks")));
Kotlin
코틀린을 사용하는 경우도 Java와 동일합니다. Log
와 Exception
을 이용하여 Call stack을 출력하기 때문에 다음과 같이 사용하시면 됩니다.
Log.d(TAG, "Call stack", Throwable("get stacks"));
try {
throw Exception("get stacks")
} catch (e: Exception) {
e.printStackTrace()
}
Log.d(TAG, Log.getStackTraceString(Exception("get stacks")))
Loading script...
Related Posts
- Android 14 - 사진/동영상 파일, 일부 접근 권한 소개
- Android - adb push, pull로 파일 복사, 다운로드
- Android 14 - 암시적 인텐트 변경사항 및 문제 해결
- Jetpack Compose - Row와 Column
- Android 13, AOSP 오픈소스 다운로드 및 빌드
- Android 13 - 세분화된 미디어 파일 권한
- Android 13에서 Notification 권한 요청, 알림 띄우기
- Android 13에서 'Access blocked: ComponentInfo' 에러 해결
- 에러 해결: android gradle plugin requires java 11 to run. you are currently using java 1.8.
- 안드로이드 - 코루틴과 Retrofit으로 비동기 통신 예제
- 안드로이드 - 코루틴으로 URL 이미지 불러오기
- Android - 진동, Vibrator, VibrationEffect 예제
- Some problems were found with the configuration of task 에러 수정
- Query method parameters should either be a type that can be converted into a database column or a List
- 우분투에서 Android 12 오픈소스 다운로드 및 빌드
- Android - ViewModel을 생성하는 방법
- Android - Transformations.map(), switchMap() 차이점
- Android - Transformations.distinctUntilChanged() 소개
- Android - TabLayout 구현 방법 (+ ViewPager2)
- Android - 휴대폰 전화번호 가져오는 방법
- Android 12 - Splash Screens 알아보기
- Android 12 - Incremental Install (Play as you Download) 소개
- Android - adb 명령어로 bugreport 로그 파일 추출
- Android - adb 명령어로 App 데이터 삭제
- Android - adb 명령어로 앱 비활성화, 활성화
- Android - adb 명령어로 특정 패키지의 PID 찾기
- Android - adb 명령어로 퍼미션 Grant 또는 Revoke
- Android - adb 명령어로 apk 설치, 삭제
- Android - adb 명령어로 특정 패키지의 프로세스 종료
- Android - adb 명령어로 screen capture 저장
- Android - adb 명령어로 System 앱 삭제, 설치
- Android - adb 명령어로 settings value 확인, 변경
- Android 12 - IntentFilter의 exported 명시적 선언
- Android - adb 명령어로 공장초기화(Factory reset)
- Android - adb logcat 명령어로 로그 출력