【问题标题】:Error only when running on actual phone (not emulator)仅在实际手机(而非模拟器)上运行时出错
【发布时间】:2015-02-26 18:54:50
【问题描述】:

在 Android Studio 中制作我的应用程序时,我主要是在模拟器上运行/测试它。好吧,我已经完成了它(我想),我在手机上运行了它,这是我之前很久以前做过的。现在,当我开始一项活动时,我应该选择一些问题(测验应用程序)来进行我想参加的练习测试,然后点击“开始”。在我的实际手机上,这会发送一个错误并显示该应用程序已不幸停止工作的消息。然后应用程序会重置。

       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$1.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$1.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$1.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>

【问题讨论】:

  • chooseTestLength.java:57 中的内容(在您的崩溃日志中找到)
  • 我编辑了问题以包含与问题相关的 java 文件。
  • 我认为您的代码中缺少某些内容。我看不到 sendLengthOnClick 何时被调用...但是根据错误消息,我敢打赌 TEST_LENGTH 变量在“intent.putExtra(TEST_LENGTH, num);”时为空被调用。

标签: android android-emulator


【解决方案1】:

看起来您要么在从第 57 行的 godwin.com.study.chooseTestLength.sendLengthOnClick() 函数调用的 Intent.putExtra() 方法中传入 NULL 值,要么 Intent 本身为 NULL。请发布一些代码以更好地评估问题。

编辑:

如前所述,TEST_LENGTH 为 NULL。给它一个像这样的值:

public static String TEST_LENGTH = "TEST_LENGTH";

Intent extras 用作键/值对。 TEST_LENGTH 是您的密钥,num 是您的值。键不能为 NULL。根据对象类型,值有时可以为 NULL。

【讨论】:

  • 嘿,我刚刚做了,您还需要评估这个问题吗?
  • 我刚刚看到了,但现在我很好奇为什么它可以像我预期的那样在模拟器上工作。我认为putExtra 将变量名和值作为参数。所以TEST_LENGTH 是变量名,num 保存该值,以便我可以在下一个调用的活动中使用getExtra。如果不是这种情况,我应该如何使用putExtragetExtra 方法?
  • 啊,我现在看到你编辑的代码了。我试过了,它奏效了!虽然,我真的希望我理解为什么它在模拟器而不是手机中工作的情况,但是添加它如何让它现在可以在两者上工作。还是一样,非常感谢。
  • 在您开始的活动中,您可以通过调用 getIntent().getExtra(chooseTestLength.TEST_LENGTH)(通常在 onCreate() 方法中)获取您传递的值并将其存储在其中如果需要,新的 Activity 或立即使用它。
  • 对,我以前做过。就像我说的,当我在 Galaxy S4 上运行该应用程序时,该应用程序在模拟器上运行,而不是在手机上运行。所以,虽然它现在适用于两者,但我仍然不明白为什么它以前适用于一个而不是另一个。我第一次正确实现了 getExtra 和 putExtra。
最近更新 更多