5

どういうわけかLogCatログを監視する必要があります。つまり、サービスの実行中にLogCatを読み取って新しいエントリを探す必要があります。現時点では、ログを1回取得する方法しか知りません。

Process mLogcatProc = null;
    BufferedReader reader = null;
    try
    {
            mLogcatProc = Runtime.getRuntime().exec(new String[]
                   {"logcat", "-d", "ActivityManager:I *:S" });        

            reader = new BufferedReader(new InputStreamReader
    (mLogcatProc.getInputStream()));

            String line;
            final StringBuilder log = new StringBuilder();
            String separator = System.getProperty("line.separator"); 

            while ((line = reader.readLine()) != null)
            {
                    log.append(line);
                    log.append(separator);
            }

-dオプションを削除すると、終了しませんが、どちらも機能しません。では、LogCatから新しいエントリを継続的に読み取るために、次のコードを変更するにはどうすればよいですか?

4

2 に答える 2

6

これは、Jiahao Liu の提案を使用して、私が行った方法です。

ReadThread thread;

public void startRecordingLogs()
{
  if(thread == null || !thread.isAlive())
  {
    ReadThread thread = new ReadThread();
    thread.start();
  }
}

public String stopRecordingLogs()
{
  String results = thread.stopLogging();
  return results;
}

private class ReadThread extends Thread{

  String results;
  Process process;
  Object lockObject = new Object();

  public void run(){
    synchronized(lockObject)
    {
      process = Runtime.getRuntime().exec("logcat -v time");        

      reader = new BufferedReader(new InputStreamReader (process.getInputStream()));

      String line;
      final StringBuilder log = new StringBuilder();
      String separator = System.getProperty("line.separator"); 

      while ((line = reader.readLine()) != null)
      {
        log.append(line);
        log.append(separator);
      }
    }

    results = log.toString();
  }

  public String stopLogging()
  {
    process.destroy();
    synchronized(lockObject)
    {
      return results;
    }
  }
}
于 2012-08-09T04:51:06.473 に答える
2

バックグラウンドで (オプション -d なしで) logcat を実行するための新しいスレッドを作成できます。

注: プロセス ActivityManager の代わりにバッファ イベントを使用すると、より正確になります。「logcat -b イベント」

于 2011-05-01T19:32:12.330 に答える