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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

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

Q&A

解決済

2回答

5897閲覧

AndroidStudioを使用しprintStackTraceでLogcatにスタックトレースを出す方法

I_LIKE_EGGS

総合スコア11

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

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

0グッド

0クリップ

投稿2020/06/10 07:44

編集2020/06/10 09:31

AndroidStudio3.6を使用しe.printStackTraceをした際どのようにすれはLogcatにスタックトレースを出力できるのでしょうか?

try { aa(); } catch (Exception e) { e.printStackTrace(); } } public void aa()throws Exception{ throw new Exception(); }

ちなみに現状ここまではわかっています。

1.printStackTrace()とは戻り値voidのThrowableクラスのメソッドという事(戻り値voidの為、System.out.println()やLog()の第3引数にe.printStackTrace()を入れようが出ない。そもそもLog()の第三引数に入れれない。入れるとエラー)。
2.printStackTrace()は標準エラー出力に出力するという事。
その為、上記ソースでは標準エラー出力がLogcatで出ない為、でないという事がわかりました。
そもそもLogcatって何?って話になりますが、

あと

e.printStackTrace();

のところを

Log.i("test", "test", new Throwable());

とすればとりあえずはLogCatに出力出来るという事まではわかりました。

追記1
追加修正依頼からAndroidStudio4.0を使用している回答者様の環境では出力されたようです。
恐らく自分の環境(androidstudio3.6.3)に問題があると思います。
バージョンのせいなのか、はたまた設定のせいなのか…

追記2
追加依頼者様からのフィルターの助言により確認したところ、logcagt右上のドロップダウンリストがshow only selected applicationになっていました。No Filtersにしたところログはたくさん出る様になったのですが、肝心なprintStackTrace()でのログは出ていないようす…
androidstudioもバージョン4.0にしましたが、ダメなようす…
問題はどこだ…?

一応logcatのスクリーンショットを載せておきます。
(どのように設定してあるかわかる為)
(logcatの表示にスタックトレースが出ていますが、今回の質問とは関係ありません。恐らく…)
イメージ説明

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

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

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

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

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

I_LIKE_EGGS

2020/06/10 08:33

本当ですか…。 じゃあ自分の環境が悪いのかな… 引き続き調べてみますm(__)m
hoshi-takanori

2020/06/10 08:44

念のためにそのコードを Android Studio 4..0 の新規プロジェクトに貼り付けて実行してみましたが、ちゃんと表示されましたよ。LogCat のフィルターの設定によっては隠されちゃう場合もあるので、ご確認ください。
I_LIKE_EGGS

2020/06/10 08:56

そうなんですか!じゃあ完璧自分の環境のせいですね!ご助言ありがとうございます! 自分の再構築の方に力を注いでみます!
hoshi-takanori

2020/06/10 09:41

スクショの Error のところを Warn にしたら表示されると思います。
I_LIKE_EGGS

2020/06/14 13:07

表示されました。こんな簡単なところに…。 感謝です!
guest

回答2

0

自己解決

Logcatの表示の種類がERRORだと思っていましたが、追加依頼欄のコメントによりWarnにしたところ表示できました。
ErrorではなくWarnなのはなぜなのか疑問が残りますがとりあえず解決出来ました。
ご回答、コメント頂けた方、ありがとうございます。

投稿2020/06/14 13:12

I_LIKE_EGGS

総合スコア11

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

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

0

e.getStackTrace()でスタックトレースの各行を取得できます。

java

1try { 2 aa(); 3} catch (Exception e) { 4 String error = ""; 5 for(StackTraceElement elem: e.getStackTrace()) { 6 error += elem.toString(); 7 } 8 9 Log.e(タグ, error); 10}

投稿2020/06/10 08:34

mingos

総合スコア4207

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

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

I_LIKE_EGGS

2020/06/10 08:40

getStackTrace()でStackTraceElement型の配列を返すんですね! printStackTrace()は出ないんでしょうか?引き続きわかればご回答お願いしますm(__)m
I_LIKE_EGGS

2020/06/14 13:08

こちらも使えましたね!ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問