Как я могу исправить ошибку принудительного закрытия в моем приложении - PullRequest
0 голосов
/ 31 марта 2012

Я могу найти ошибку в моих приложениях. Когда я пытаюсь запустить мои приложения, появляется ошибка принудительного закрытия.

public class Main extends Activity {
Button btnAdd;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    btnAdd = (Button) findViewById(R.id.btnAdd);
    btnAdd.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            // TODO Auto-generated method stub
            Intent listIntent = new Intent (v.getContext(),Newbook.class) ;
            startActivity(listIntent);
        }
    });
}

}

и ошибка журнала cat

03-31 16:05:57.493: D/AndroidRuntime(387): Shutting down VM
03-31 16:05:57.493: W/dalvikvm(387): threadid=3: thread exiting with uncaught exception (group=0x4001b188)
03-31 16:05:57.503: E/AndroidRuntime(387): Uncaught handler: thread main exiting due to uncaught exception
03-31 16:05:57.597: E/AndroidRuntime(387): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.sam.daybook/com.sam.daybook.DayBookActivity}: java.lang.ClassNotFoundException: com.sam.daybook.DayBookActivity in loader dalvik.system.PathClassLoader@44e8d908
03-31 16:05:57.597: E/AndroidRuntime(387):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2417)
03-31 16:05:57.597: E/AndroidRuntime(387):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
03-31 16:05:57.597: E/AndroidRuntime(387):  at android.app.ActivityThread.access$2200(ActivityThread.java:119)
03-31 16:05:57.597: E/AndroidRuntime(387):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
03-31 16:05:57.597: E/AndroidRuntime(387):  at android.os.Handler.dispatchMessage(Handler.java:99)
03-31 16:05:57.597: E/AndroidRuntime(387):  at android.os.Looper.loop(Looper.java:123)
03-31 16:05:57.597: E/AndroidRuntime(387):  at android.app.ActivityThread.main(ActivityThread.java:4363)
03-31 16:05:57.597: E/AndroidRuntime(387):  at java.lang.reflect.Method.invokeNative(Native Method)
03-31 16:05:57.597: E/AndroidRuntime(387):  at java.lang.reflect.Method.invoke(Method.java:521)
03-31 16:05:57.597: E/AndroidRuntime(387):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
03-31 16:05:57.597: E/AndroidRuntime(387):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
03-31 16:05:57.597: E/AndroidRuntime(387):  at dalvik.system.NativeStart.main(Native Method)
03-31 16:05:57.597: E/AndroidRuntime(387): Caused by: java.lang.ClassNotFoundException: com.sam.daybook.DayBookActivity in loader dalvik.system.PathClassLoader@44e8d908
03-31 16:05:57.597: E/AndroidRuntime(387):  at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
03-31 16:05:57.597: E/AndroidRuntime(387):  at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
03-31 16:05:57.597: E/AndroidRuntime(387):  at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
03-31 16:05:57.597: E/AndroidRuntime(387):  at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
03-31 16:05:57.597: E/AndroidRuntime(387):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2409)
03-31 16:05:57.597: E/AndroidRuntime(387):  ... 11 more
03-31 16:05:57.684: I/dalvikvm(387): threadid=7: reacting to signal 3
03-31 16:05:57.863: I/dalvikvm(387): Wrote stack trace to '/data/anr/traces.txt'

Ответы [ 4 ]

0 голосов
/ 02 апреля 2012

Попробуйте добавить следующие строки в манифест Android нашего проекта

<activity android:name="NAME_OF_YOUR_CLASS">
  <intent-filter>
     <action android:name="NAME_OF_YOUR_INTENT"/>
     <category android:name="android.intent.category.DEFAULT"/>
  </intent-filter>
</activity>

Затем начните свою деятельность, используя следующую строку

startActivity(new Intent("NAME_OF_YOUR_INTENT"));

убедитесь, что имя вашего намерения в приведенной выше строке и в манифесте точно совпадает.

0 голосов
/ 31 марта 2012

Похоже, Android не может найти ваш класс активности: Это говорит о том, что создание экземпляра действия невозможно из вашего кода.

Unable to instantiate activity ComponentInfo{com.sam.daybook/com.sam.daybook.DayBookActivity}: 

Тогда это говорит вам, что класс com.sam.daybook.DayBookActivity не может быть найден.

java.lang.ClassNotFoundException: com.sam.daybook.DayBookActivity in loader

Существует ли класс DayBookActivity внутри src/com/sam/daybook/?

Код, который вы опубликовали, был предназначен для класса с именем Main, если вы планируете загрузить это действие, я думаю, вам может потребоваться переименовать класс в DayBookActivity. Вам также необходимо переименовать файл Main.java в DayBookActivity.java.

0 голосов
/ 31 марта 2012

попробуйте это Intent listIntent = new Intent (Main.this, Newbook.class);

0 голосов
/ 31 марта 2012

В этом отсутствии ошибок вы можете найти ошибку, которая приводит к сбою приложения по имени вашего пакета, например:

com.sam.daybook

и класс или вид деятельности:

com.sam.daybook.DayBookActivity

и правильная ошибка:

 java.lang.ClassNotFoundException: com.sam.daybook.DayBookActivity in loader dalvik.system.PathClassLoader@44e8d908 03-31 16:05:57.597:

Я надеюсь, что это, вероятно, поможет вам ...

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...