質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Q&A

解決済

3回答

5677閲覧

Androidで "連続的" にlogcatメッセージを取得する。

t.mori

総合スコア22

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

0グッド

0クリップ

投稿2015/06/14 06:12

Android でlogcat を連続的に取得したいのですが、上手くいかず困っています。

具体的には、adb logcat のログを表示もしくはDBに書き出したいのですが、
logcat -d で1度だけダンプできても、ログを連続的に取得することができず
悩んでいます。

UIスレッドに接触しないように、AsyncTaskのdoInBackground(Void...params)で

lang

1Process process = Runtime.getRuntime().exec("logcat"); 2BufferedReader buf = new BufferedReader(new InputStreamReader(process.getInputStream(),1024)); 3 4String line; 5while((line=bufferedReader.readLine())!=null){ 6 Log.i("Logcat",line); 7} 8

でログに書き出しているのですが、
処理が止まらなくなり、thread errorまたはmemory leakになりました。

exec("logcat -d")で1度だけログをとれるのですが、連続的にLogをとりたい(logcatの垂れ流し状態)ため、悩んでいます。

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

みなさん回答有難うございました。
結果的にはhandler とMessageを使ってスレッドで解決できました。
有難うございました!

投稿2015/06/24 15:31

t.mori

総合スコア22

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

BufferedReader buf = new BufferedReader(new InputStreamReader(process.getInputStream(),1024));

バッファの数が1024なので、メモリーがオーバーフローしているのじゃないですか?

投稿2015/06/16 01:12

MasaakiIrie

総合スコア1021

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

実行前に一旦ログをクリア(Runtime.getRuntime().exec("logcat -c");)するなどしても、メモリリークになりますでしょうか?

またはRuntime.getRuntime().exec("logcat")する時にtag:Wなどをオプションを指定する事で、大量のログ取得を抑制できるかと思います。

参考
http://wikiwiki.jp/android/?Android%A5%A2%A5%D7%A5%EA%A5%B1%A1%BC%A5%B7%A5%E7%A5%F3%A4%AB%A4%E9logcat%A5%B3%A5%DE%A5%F3%A5%C9%A4%F2%BC%C2%B9%D4%A4%B9%A4%EB

投稿2015/06/14 06:42

chiku_

総合スコア1464

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問