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

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

ただいまの
回答率

90.48%

  • Java

    14145questions

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

  • Android

    6635questions

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

  • Android Studio

    3800questions

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

「問題が発生したため、アプリ名を終了します。」と表示されてしまう。

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 794

kumakumatan

score 127

Android Studioでアプリを作成してビルドまでは上手く行ったのですが、
アプリが起動されてすぐ、「問題が発生したため、アプリ名を終了します。」
と表示されて画面が閉じられてしまいます。
ちなみに「アプリ名」は「アンドロイドアプリ名」です。

どこをどう調査して修正したらいいのかわからず困っています。

「Android Monitor」でのログを表示致します。

09-26 10:40:13.990 12811-12811/org.test.myapplication.App2 E/AndroidRuntime: FATAL EXCEPTION: main

Process: org.test.myapplication.App2, PID: 12811
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{org.test.myapplication.App2/org.test.myapplication.App2.MainActivity}: java.lang.ClassNotFoundException: Didn't find class "org.test.myapplication.App2.MainActivity" on path: DexPathList[[zip file "/data/app/org.test.myapplication.App2-2/base.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_dependencies_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_0_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_1_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_2_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_3_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_4_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_5_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_6_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_7_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_8_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_9_apk.apk"],nativeLibraryDirectories=[/vendor/lib64, /system/lib64]]
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2310)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2464)
at android.app.ActivityThread.access$1000(ActivityThread.java:161)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1371)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5438)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:917)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:712)
Caused by: java.lang.ClassNotFoundException: Didn't find class "org.test.myapplication.App2.MainActivity" on path: DexPathList[[zip file "/data/app/org.test.myapplication.App2-2/base.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_dependencies_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_0_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_1_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_2_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_3_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_4_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_5_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_6_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_7_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_8_apk.apk", zip file "/data/app/org.test.myapplication.App2-2/split_lib_slice_9_apk.apk"],nativeLibraryDirectories=[/vendor/lib64, /system/lib64]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
at android.app.Instrumentation.newActivity(Instrumentation.java:1065)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2300)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2464)?
at android.app.ActivityThread.access$1000(ActivityThread.java:161)?
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1371)?
at android.os.Handler.dispatchMessage(Handler.java:102)?
at android.os.Looper.loop(Looper.java:135)?
at android.app.ActivityThread.main(ActivityThread.java:5438)?
at java.lang.reflect.Method.invoke(Native Method)?
at java.lang.reflect.Method.invoke(Method.java:372)?
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:917)?
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:712)?
Suppressed: java.lang.ClassNotFoundException: org.test.myapplication.App2.MainActivity
at java.lang.Class.classForName(Native Method)
at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
... 13 more
Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available

宜しくお願いします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • mts10806

    2017/09/26 10:23

    質問文が途中で切れている気がしますが、編集中ですかね? あと→ https://teratail.com/help/question-tips#questionTips3-5

    キャンセル

  • yona

    2017/09/26 10:34

    エラーログを質問に追記してください。

    キャンセル

  • kumakumatan

    2017/09/26 10:49

    エラーログを記載しました。宜しくお願いします。

    キャンセル

回答 2

checkベストアンサー

0

以下の事象も同じものです。
https://stackoverflow.com/questions/4688277/java-lang-runtimeexception-unable-to-instantiate-activity-componentinfo

さて,AndroidではActivityは特別なクラスなので,AndroidManifestに「このクラスはActivityだよ(アプリの画面になるよ)」ということを書いてあげる必要があります。
今回は画面を構成するためのActivityですが,バックグラウンド処理を行うService,OSからのブロードキャストを受け取るBroadcastReceiverなども同様にAndroidManifestへの記載が必要になります。

今回の件だとAndroidManifestはこんな感じです。

...
<application
        android:name="org.test.myapplication.App2" // ←多分こうなっていると思いますが,既に記述があればそのままでいいです
        android:allowBackup="true" // ←ここから"supportRtl"属性も,今回は手を加えなくていいです
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true">

        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
</application>
...

大事なのは<activity>タグですが,このうちandroid:name属性で対象のActivityクラスを指定します。自身のパッケージ名も含めたフルクラス名(org.test.myapplication.App2.MainActivity)でもいいのですが,今回のように冒頭にドットを入れて.MainActivityとしても同じ事です。

intent-filterは種類が色々ありますが,今回の例で言えば,

  • <action android:name="android.intent.action.MAIN" />:アプリアイコンをタップして一番最初に起動するActivityであることを指定
  • <category android:name="android.intent.category.LAUNCHER" />: ホームアプリに表示するActivityであることを指定

の意味があります。

ちなみに,一番最初に起動するActivity以外では単純に<activity android:name="..."></activity>もしくは<activity android:name="..."/>とすればOKです。


AndroidStudio上では右クリックからActivityを追加することができます。
イメージ説明

このとき,AndroidStudioは空気を読んでくれるのでAndroidManifestへの記述も自動で追加してくれます。
@kumakumatanさんは恐らく通常のクラスファイルと同様にJavaファイルを追加,としてActivityを作ったのでしょうね。

// 当然ながら,どちらで作成しても大丈夫です

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/09/27 16:23

    ありがとうございます。
    お陰様で解決できました。
    有難うございました。

    キャンセル

0

Activityを作ったときにAndroidStudioの機能を使わずにマニフェストファイルにactivityタグを追記しましたか?

AndroidStudioの機能を使わずにActivityを追加した場合はマニフェストファイルを手動で変更しないといけません。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/09/26 11:41

    ご回答ありがとうございます。

    >Activityを追加した場合はマニフェストファイルを手動で変更

    どのようにするのでしょうか?
    ご教授宜しくお願いします。

    キャンセル

  • 2017/09/26 11:47 編集

    まずはリファレンスを読みましょう。
    https://developer.android.com/guide/topics/manifest/manifest-intro.html?hl=ja

    キャンセル

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

  • ただいまの回答率 90.48%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Java

    14145questions

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

  • Android

    6635questions

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

  • Android Studio

    3800questions

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