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

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

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

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

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Q&A

1回答

20915閲覧

adb logcatコマンドで、アプリを指定してログを出したいのですが。

TACOSMAN

総合スコア13

Android

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

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

0グッド

0クリップ

投稿2017/08/03 11:48

■Androidバージョン
Android5.1

■開発環境
Windows7
AndroidStudio2.3

現在Androidスマホアプリを一つ作成しており、任意のタイミングでサービスからlogcatログの監視を開始して、その作成しているアプリのログを端末内のファイルに出力させる機能を実装中です。
ログが吐かれる度に一行ずつファイルに出力させる機能は実装できたのですが、作成しているアプリのみを指定したログの出力ができておりません。
AndroidStudioではパッケージを指定して、表示されるログにフィルタを掛けられると思っているのですが、adb logcatコマンドではそういった事はできないのでしょうか?
また代替手法などあるのでしょうか?

宜しくお願い致します。

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

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

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

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

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

guest

回答1

0

手元に環境がなく、未検証の回答で恐縮ですが、、

マニュアルを見る限り、logcat 自体にパッケージ名でフィルタリングする機能はなさそうです。
https://developer.android.com/studio/command-line/logcat.html?hl=en#Syntax

stackoverflow には
「対象のアプリの PID でフィルタリングする」
という方法が紹介されていましたが、
回答を見る限り Android7.0以上でのみ可能な方法のようで、お使いの環境 (Android5.1) では不可能かもしれません。
https://stackoverflow.com/a/32737594


私に思いつく代替方法としては、
「作成中のアプリから出力するログのタグ(Log.d()Log.e()メソッドの第一引数)を
すべて特定の文字列に統一し、logcat コマンドからはそのタグ名でフィルタリングする」
というものです。

具体的な logcat コマンドは、以下のようになるかと思います。

sh

1adb logcat 特定の文字列:V *:S

https://developer.android.com/studio/command-line/logcat.html?hl=en#filteringOutput

もちろん、別のアプリが同じタグでログ出力しているとそれも表示してしまう、というデメリットはありますが、
タグをアプリのパッケージ名にしておけば、そのようなことはまず起きないと思います。


ちなみに

AndroidStudioではパッケージを指定して、表示されるログにフィルタを掛けられる

理由は、おそらく 指定したパッケージ名から PID を割り出し(pidof <パッケージ名>でわかるはず)、
さらに出力されたログの中に含まれる PID を解析してフィルタリングしているのだと思われます。
https://developer.android.com/studio/command-line/logcat.html?hl=en#outputFormat

threadtime (default): Display the date, invocation time, priority, tag, PID, and TID of the thread issuing the message.

投稿2017/08/03 12:40

KiyoshiMotoki

総合スコア4791

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問