android如何以编程方式仅捕获应用程序中的我的日志条目

时间:2017-03-17 10:06:40

标签: android android-logcat android-log

我想单独获取我在应用程序中放入的日志条目,并在可滚动的textview中显示它。例如

Log.e(SAMPLE_ACTIVITY_TAG, "App started") 

我只需要那些错误日志,我不想要其他不需要的日志。是否可以通过logcat命令行工具?我尝试了下面的代码,但我得到了完整的应用程序设备日志

 Process process = Runtime.getRuntime().exec("logcat -d");
        BufferedReader bufferedReader = new BufferedReader(
                new InputStreamReader(process.getInputStream()));

        StringBuilder log=new StringBuilder();
        String line = "";
        while ((line = bufferedReader.readLine()) != null) {
            log.append(line +"\n");
        }
        textView.setText(log.toString());
        textView.setMovementMethod(new ScrollingMovementMethod());

任何建议

1 个答案:

答案 0 :(得分:2)

请使用以下给定命令创建过程对象:

logcat --pid = PID -d

您需要将PID替换为您的应用程序进程ID。可以使用下面的代码行

获取进程ID
int pid = android.os.Process.myPid();

您的最终源代码应该是这样的。请试一试

        int pid = android.os.Process.myPid();
        String command = "logcat --pid="+pid+" -d";
        Process process = Runtime.getRuntime().exec(command);
        BufferedReader bufferedReader = new BufferedReader(
                new InputStreamReader(process.getInputStream()));

        StringBuilder log=new StringBuilder();
        String line = "";
        while ((line = bufferedReader.readLine()) != null) {
            log.append(line +"\n");
        }
        textView.setText(log.toString());
        textView.setMovementMethod(new ScrollingMovementMethod());