Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/216.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 在同一活动中打开活动_Android_Android Intent_Android Activity - Fatal编程技术网

Android 在同一活动中打开活动

Android 在同一活动中打开活动,android,android-intent,android-activity,Android,Android Intent,Android Activity,当按下按钮时,我尝试以不同的参数打开与我当前所在的类相同的类。我是这样做的: Intent j = new Intent("com.test.com.ANSWER"); id = calculateId(0); j.putExtra("id", Long.toString(id)); startActivityForResult(j, 0); 但是我得到一个空指针异常。。是否有一些规则规定您不能打开同一活动本身 错误: 1

当按下按钮时,我尝试以不同的参数打开与我当前所在的类相同的类。我是这样做的:

Intent j = new Intent("com.test.com.ANSWER");
            id = calculateId(0);
            j.putExtra("id", Long.toString(id));
            startActivityForResult(j, 0);
但是我得到一个空指针异常。。是否有一些规则规定您不能打开同一活动本身

错误:

12-01 01:29:10.314: E/AndroidRuntime(2194): FATAL EXCEPTION: main
12-01 01:29:10.314: E/AndroidRuntime(2194): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.test/com.test.Answer}: java.lang.NullPointerException
12-01 01:29:10.314: E/AndroidRuntime(2194):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at android.os.Handler.dispatchMessage(Handler.java:99)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at android.os.Looper.loop(Looper.java:130)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at android.app.ActivityThread.main(ActivityThread.java:3683)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at java.lang.reflect.Method.invokeNative(Native Method)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at java.lang.reflect.Method.invoke(Method.java:507)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:861)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:619)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at dalvik.system.NativeStart.main(Native Method)
12-01 01:29:10.314: E/AndroidRuntime(2194): Caused by: java.lang.NullPointerException
12-01 01:29:10.314: E/AndroidRuntime(2194):     at com.test.Answer.onCreate(Answer.java:86)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
12-01 01:29:10.314: E/AndroidRuntime(2194):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)

我想你的身份证没有初始化。您正在尝试使用使用id的函数初始化它,这样它就永远不会有值。如果不是这样,那么在不同的地方使用相同的变量名,这通常不是很好的做法

我不确定这是否有规则,但我也不确定这是否是个好主意。如果这是您需要做的,那么可能应该有一个类,您可以将其子类化。空指针异常在哪里?它可能与calculateId()或其他地方之类的其他东西有关。你能发布logcat吗?我添加了错误消息!Ps,这不是我的想法,因为如果我把它改为1,例如,我仍然会得到这个信息。onCreate的第86行是什么,你的计算方法是什么样子的?为什么你要开始相同的活动来获得结果?如果需要在活动中循环使用不同的UI模式,可以考虑使用片段,它是如何获得价值的?“id”对该函数可见吗?它是否初始化过?