离线调试Android应用程序

时间:2012-04-11 07:52:53

标签: android debugging

我正在开发一个使用位置服务的应用程序。我需要使用Log.d()调试应用程序,但需要将设备连接到计算机。这对我来说是不可能的。我将在旅行中测试该应用程序约两个小时。我当时无法将它连接到PC。

有没有办法保存手机中的日志并在以后检索它,并且可以看到LOG数据。

2 个答案:

答案 0 :(得分:3)

引入您自己的Logger类,它是android.util.Log类的包装器,它将输出重定向到文件和控制台:

public class Logger {

    public static PrintWriter printWriter = null;

    private static void init() {
        ...
        // Check if external media is writable
        ...

        if (printWriter == null) {
            try {
                File dir = new File(Environment.getExternalStorageDirectory() + LOG_DIR);
                dir.mkdirs();
                printWriter = new PrintWriter(new FileWriter(new File(dir, LOG_FILE), true));
            }
            catch (IOException e) {
                Log.e(Logger.class.getName(), "initExternal() -> IOException", e);
            }
        }
    }

    private static synchronized int log(int priority, String tag, String msg) {
        int res = Log.println(priority, tag, msg);

        init(); // May be called just once, depending on your requirements

        printWriter.print(tag + "   ");
        printWriter.print(msg + "\r\n");
        printWriter.flush();
        return res;
    }


    // Duplicates of standard android.util.Log methods:
    public static int v(String tag, String msg) {
        return log(Log.VERBOSE, tag, msg);
    }
    public static int v(String tag, String msg, Throwable tr) {
        return log(Log.VERBOSE, tag, msg + '\n' + Log.getStackTraceString(tr));
    }
    public static int d(String tag, String msg) {
        return log(Log.DEBUG, tag, msg);
    }
    public static int d(String tag, String msg, Throwable tr) {
        return log(Log.DEBUG, tag, msg + '\n' + Log.getStackTraceString(tr));
    }

    ...

}

答案 1 :(得分:1)

有些应用程序可以获取日志的最后几百行,并通过电子邮件发送到您要发送到的任何电子邮件。我用过日志收集器 https://play.google.com/store/apps/details?id=com.xtralogic.android.logcollector&feature=search_result#?t=W251bGwsMSwyLDEsImNvbS54dHJhbG9naWMuYW5kcm9pZC5sb2djb2xsZWN0b3IiXQ .. 并且可以推荐它,完成你需要做的工作:D