Android:エラー発生時から原因調査・解決方法について
原因調査手順
1.ログを見る
----------
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.sampleweathersamplejavaapplication, PID: 8670
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.sampleweathersamplejavaapplication/com.example.sampleweathersamplejavaapplication.MainActivity}: android.view.InflateException: Binary XML file line #27 in com.example.sampleweathersamplejavaapplication:layout/abc_screen_toolbar: Binary XML file line #27 in com.example.sampleweathersamplejavaapplication:layout/abc_screen_toolbar: Error inflating class androidx.appcompat.widget.ActionBarContainer
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3449)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3601)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:85)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2066)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:223)
at android.app.ActivityThread.main(ActivityThread.java:7656)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)
Caused by: android.view.InflateException: Binary XML file line #27 in com.example.sampleweathersamplejavaapplication:layout/abc_screen_toolbar: Binary XML file line #27 in com.example.sampleweathersamplejavaapplication:layout/abc_screen_toolbar: Error inflating class androidx.appcompat.widget.ActionBarContainer
Caused by: android.view.InflateException: Binary XML file line #27 in com.example.sampleweathersamplejavaapplication:layout/abc_screen_toolbar: Error inflating class androidx.appcompat.widget.ActionBarContainer
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Constructor.newInstance0(Native Method)
at java.lang.reflect.Constructor.newInstance(Constructor.java:343)
at android.view.LayoutInflater.createView(LayoutInflater.java:852)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:1004)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:959)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:1121)
at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:1082)
at android.view.LayoutInflater.inflate(LayoutInflater.java:680)
at android.view.LayoutInflater.inflate(LayoutInflater.java:532)
at android.view.LayoutInflater.inflate(LayoutInflater.java:479)
at androidx.appcompat.app.AppCompatDelegateImpl.createSubDecor(AppCompatDelegateImpl.java:905)
at androidx.appcompat.app.AppCompatDelegateImpl.ensureSubDecor(AppCompatDelegateImpl.java:815)
at androidx.appcompat.app.AppCompatDelegateImpl.setContentView(AppCompatDelegateImpl.java:703)
at androidx.appcompat.app.AppCompatActivity.setContentView(AppCompatActivity.java:195)
at com.example.sampleweathersamplejavaapplication.MainActivity.onCreate(MainActivity.java:12)
at android.app.Activity.performCreate(Activity.java:8000)
at android.app.Activity.performCreate(Activity.java:7984)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1309)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3422)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3601)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:85)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2066)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:223)
E/AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:7656)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)
Caused by: java.lang.NoSuchMethodError: No static method metafactory(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite; in class Ljava/lang/invoke/LambdaMetafactory; or its super classes (declaration of 'java.lang.invoke.LambdaMetafactory' appears in /apex/com.android.art/javalib/core-oj.jar)
at androidx.core.view.ViewCompat.
----------
上記のようなエラーログが表示された場合
- 長い英文で表示されているが基本的には各ブロックの始まりを見れば良い。
----------
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.sampleweathersamplejavaapplication/com.example.sampleweathersamplejavaapplication.MainActivity}: android.view.InflateException: Binary XML file line #27 in com.example.sampleweathersamplejavaapplication:layout/abc_screen_toolbar: Binary XML file line #27 in com.example.sampleweathersamplejavaapplication:layout/abc_screen_toolbar: Error inflating class androidx.appcompat.widget.ActionBarContainer
----------
多くの場合この始まりに、最終結果(概要)->過程(詳細)の順でエラーが起きた原因が記載されている。
「java.lang.RuntimeException」 -> 「例外が発生した」
「Unable to start activity ComponentInfo」-> 「Activityを開始する事が出来ない」
「android.view.InflateException」-> 「インフレートで例外が発生した」
等「:」区切りで詳細が記載されているので知りたい所まで原因を追う
2.該当箇所を調べる
原因が分かったら原因が該当しそうな箇所を知らべにいく。
エラーログに青文字リンクがある場合、自分で記載したコードの中でエラーが発生した事を示しているのでその箇所を重点的に見る。
3.それでもわからなければGoogle検索
エラーメッセージで検索をかける。
この際概要ではなく一番奥の詳細エラーメッセージで検索をかけた方が良い。