仅当 运行 在实际 phone 上时出错(不是模拟器)
Error only when running on actual phone (not emulator)
在 Android Studio 中制作我的应用程序,我大部分时间都是在模拟器上 running/testing 它。好吧,我已经差不多完成了(我想),我 运行 在我的 phone 上,我很早之前就已经完成了。现在,当我开始我的一项活动时,我应该 select 一些问题(测验应用程序)以进行我想参加的练习测试,然后点击 "begin"。在我实际的 phone 上,这会发送错误并显示一条消息,表明该应用程序已不幸停止工作。然后应用程序会重置。
02-26 10:42:16.458 964-964/godwin.com.study E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: godwin.com.study, PID: 964
java.lang.IllegalStateException: Could not execute method of the activity
at android.view.View.onClick(View.java:3999)
at android.view.View.performClick(View.java:4753)
at android.view.View$PerformClick.run(View.java:19562)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:146)
at android.app.ActivityThread.main(ActivityThread.java:5635)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at android.view.View.onClick(View.java:3994)
at android.view.View.performClick(View.java:4753)
at android.view.View$PerformClick.run(View.java:19562)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:146)
at android.app.ActivityThread.main(ActivityThread.java:5635)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at android.content.Intent.putExtra(Intent.java:6193)
at godwin.com.study.chooseTestLength.sendLengthOnClick(chooseTestLength.java:57)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at android.view.View.onClick(View.java:3994)
at android.view.View.performClick(View.java:4753)
at android.view.View$PerformClick.run(View.java:19562)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:146)
at android.app.ActivityThread.main(ActivityThread.java:5635)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)
at dalvik.system.NativeStart.main(Native Method)
这是按下按钮时崩溃的 java/activity 文件:
package godwin.com.study;
import android.content.Intent;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Spinner;
public class chooseTestLength extends ActionBarActivity {
public static String TEST_LENGTH;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_choose_test_length);
}
public void sendLengthOnClick (View view){
//Create new activity
Intent intent = new Intent(this, takeTest.class);
//Get spinner selection
final Spinner choiceSpinner = (Spinner) findViewById(R.id.testLengthSpinner);
int num = Integer.parseInt(choiceSpinner.getSelectedItem().toString());
intent.putExtra(TEST_LENGTH, num);
startActivity(intent);
}
}
这是 XML 文件:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="16dp"
android:background="@color/background"
tools:context="godwin.com.study.chooseTestLength">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
android:layout_centerInParent="true">
<TextView
android:id="@+id/chooseLength"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/chooseLengthText"
android:layout_gravity="center"/>
<Spinner
android:id="@+id/testLengthSpinner"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:prompt="@string/testLength"
android:entries="@array/testLengthChoice"
android:layout_gravity="center"
android:padding="10dp"/>
<Button
android:id="@+id/buttonSendLength"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:text="@string/startTest"
android:background="@color/primary"
android:onClick="sendLengthOnClick"
android:layout_gravity="center"/>
</LinearLayout>
</RelativeLayout>
您似乎在第 57 行的 godwin.com.study.chooseTestLength.sendLengthOnClick()
函数调用的 Intent.putExtra()
方法中传递了 NULL 值,或者 Intent 本身为 NULL。请 post 一些代码以更好地评估问题。
编辑:
如前所述,TEST_LENGTH
为 NULL。给它一个这样的值:
public static String TEST_LENGTH = "TEST_LENGTH";
Intent extra 作为 key/value 对工作。 TEST_LENGTH 是你的键,num 是你的值。键不能为 NULL。根据对象类型,值有时可以为 NULL。
在 Android Studio 中制作我的应用程序,我大部分时间都是在模拟器上 running/testing 它。好吧,我已经差不多完成了(我想),我 运行 在我的 phone 上,我很早之前就已经完成了。现在,当我开始我的一项活动时,我应该 select 一些问题(测验应用程序)以进行我想参加的练习测试,然后点击 "begin"。在我实际的 phone 上,这会发送错误并显示一条消息,表明该应用程序已不幸停止工作。然后应用程序会重置。
02-26 10:42:16.458 964-964/godwin.com.study E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: godwin.com.study, PID: 964
java.lang.IllegalStateException: Could not execute method of the activity
at android.view.View.onClick(View.java:3999)
at android.view.View.performClick(View.java:4753)
at android.view.View$PerformClick.run(View.java:19562)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:146)
at android.app.ActivityThread.main(ActivityThread.java:5635)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at android.view.View.onClick(View.java:3994)
at android.view.View.performClick(View.java:4753)
at android.view.View$PerformClick.run(View.java:19562)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:146)
at android.app.ActivityThread.main(ActivityThread.java:5635)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at android.content.Intent.putExtra(Intent.java:6193)
at godwin.com.study.chooseTestLength.sendLengthOnClick(chooseTestLength.java:57)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at android.view.View.onClick(View.java:3994)
at android.view.View.performClick(View.java:4753)
at android.view.View$PerformClick.run(View.java:19562)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:146)
at android.app.ActivityThread.main(ActivityThread.java:5635)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)
at dalvik.system.NativeStart.main(Native Method)
这是按下按钮时崩溃的 java/activity 文件:
package godwin.com.study;
import android.content.Intent;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Spinner;
public class chooseTestLength extends ActionBarActivity {
public static String TEST_LENGTH;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_choose_test_length);
}
public void sendLengthOnClick (View view){
//Create new activity
Intent intent = new Intent(this, takeTest.class);
//Get spinner selection
final Spinner choiceSpinner = (Spinner) findViewById(R.id.testLengthSpinner);
int num = Integer.parseInt(choiceSpinner.getSelectedItem().toString());
intent.putExtra(TEST_LENGTH, num);
startActivity(intent);
}
}
这是 XML 文件:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="16dp"
android:background="@color/background"
tools:context="godwin.com.study.chooseTestLength">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
android:layout_centerInParent="true">
<TextView
android:id="@+id/chooseLength"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/chooseLengthText"
android:layout_gravity="center"/>
<Spinner
android:id="@+id/testLengthSpinner"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:prompt="@string/testLength"
android:entries="@array/testLengthChoice"
android:layout_gravity="center"
android:padding="10dp"/>
<Button
android:id="@+id/buttonSendLength"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:text="@string/startTest"
android:background="@color/primary"
android:onClick="sendLengthOnClick"
android:layout_gravity="center"/>
</LinearLayout>
</RelativeLayout>
您似乎在第 57 行的 godwin.com.study.chooseTestLength.sendLengthOnClick()
函数调用的 Intent.putExtra()
方法中传递了 NULL 值,或者 Intent 本身为 NULL。请 post 一些代码以更好地评估问题。
编辑:
如前所述,TEST_LENGTH
为 NULL。给它一个这样的值:
public static String TEST_LENGTH = "TEST_LENGTH";
Intent extra 作为 key/value 对工作。 TEST_LENGTH 是你的键,num 是你的值。键不能为 NULL。根据对象类型,值有时可以为 NULL。