[Android] 로깅 프로그램 충돌 Log

최근에 안드로이드 프로그램을 디버깅하고 있는데 어떤 이유로 디버깅을 할 때 핸드폰이 PC에 연결되지 않고 IDE를 통해 프로그램이 붕괴된 로그를 볼 수 없기 때문에 로그가 파일에 기록될 수 있기를 바랍니다. 이미 발표된 앱에 대해서는 이 기능을 통해 버그를 수집할 수 있습니다.
package com.zxl.crash;

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.PrintStream;
import java.lang.Thread.UncaughtExceptionHandler;

public class MyCrashHandler implements UncaughtExceptionHandler{

	private static MyCrashHandler crashHandler;
	
	@Override
	public void uncaughtException(Thread thread, Throwable ex) {
		// TODO Auto-generated method stub
		if (crashHandler != null) {
			try {
				// crash log    
				FileOutputStream fileOutputStream = new FileOutputStream("/mnt/sdcard/crash_log.txt", true);
				PrintStream printStream = new PrintStream(fileOutputStream);
				ex.printStackTrace(printStream);
				printStream.flush();
				printStream.close();
				fileOutputStream.close();
			} catch (FileNotFoundException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} catch (IOException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
	} 
	
	//       
	public void init() {
		Thread.setDefaultUncaughtExceptionHandler(this);
	}
	
	private MyCrashHandler() {}
	
	//  
	public static MyCrashHandler instance() {
		if (crashHandler == null) {
			synchronized (crashHandler) {
				crashHandler = new MyCrashHandler();
			}
		}
		return crashHandler;
	}
}

좋은 웹페이지 즐겨찾기