Android 奇异力闭合

Android 奇异力闭合,android,Android,我有一个应用程序可以在Galaxy Nexus上完美运行,但当我在模拟器上运行它时(仅在某些设置上,一个是带JB的平板电脑,另一个是带android 2.1的ldpi),它崩溃了 logcat看起来像这样 03-29 16:26:16.842: D/AndroidRuntime(526): Shutting down VM 03-29 16:26:16.842: W/dalvikvm(526): threadid=3: thread exiting with uncaught exception

我有一个应用程序可以在Galaxy Nexus上完美运行,但当我在模拟器上运行它时(仅在某些设置上,一个是带JB的平板电脑,另一个是带android 2.1的ldpi),它崩溃了

logcat看起来像这样

03-29 16:26:16.842: D/AndroidRuntime(526): Shutting down VM
03-29 16:26:16.842: W/dalvikvm(526): threadid=3: thread exiting with uncaught exception (group=0x4001b188)
03-29 16:26:16.842: E/AndroidRuntime(526): Uncaught handler: thread main exiting due to uncaught exception
03-29 16:26:16.862: E/AndroidRuntime(526): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.doublep.wakey/com.doublep.wakey.Bulb}: java.lang.NullPointerException
03-29 16:26:16.862: E/AndroidRuntime(526):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2496)
03-29 16:26:16.862: E/AndroidRuntime(526):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
03-29 16:26:16.862: E/AndroidRuntime(526):  at android.app.ActivityThread.access$2200(ActivityThread.java:119)
03-29 16:26:16.862: E/AndroidRuntime(526):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
03-29 16:26:16.862: E/AndroidRuntime(526):  at android.os.Handler.dispatchMessage(Handler.java:99)
03-29 16:26:16.862: E/AndroidRuntime(526):  at android.os.Looper.loop(Looper.java:123)
03-29 16:26:16.862: E/AndroidRuntime(526):  at android.app.ActivityThread.main(ActivityThread.java:4363)
03-29 16:26:16.862: E/AndroidRuntime(526):  at java.lang.reflect.Method.invokeNative(Native Method)
03-29 16:26:16.862: E/AndroidRuntime(526):  at java.lang.reflect.Method.invoke(Method.java:521)
03-29 16:26:16.862: E/AndroidRuntime(526):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
03-29 16:26:16.862: E/AndroidRuntime(526):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
03-29 16:26:16.862: E/AndroidRuntime(526):  at dalvik.system.NativeStart.main(Native Method)
03-29 16:26:16.862: E/AndroidRuntime(526): Caused by: java.lang.NullPointerException
03-29 16:26:16.862: E/AndroidRuntime(526):  at com.doublep.wakey.Bulb.onCreate(Bulb.java:465)
03-29 16:26:16.862: E/AndroidRuntime(526):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
03-29 16:26:16.862: E/AndroidRuntime(526):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459)
03-29 16:26:16.862: E/AndroidRuntime(526):  ... 11 more
03-29 16:26:16.882: I/dalvikvm(526): threadid=7: reacting to signal 3
03-29 16:26:16.882: E/dalvikvm(526): Unable to open stack trace file '/data/anr/traces.txt': Permission denied
03-29 16:26:18.752: I/Process(526): Sending signal. PID: 526 SIG: 9
我发现,如果我注释掉一个按钮,问题就会消失(这是以前的imageButton,但我将其转换为button,因为imageButton工作正常)

在注释了上面的几行之后,一切都很好 这是按钮的xml

<Button
                    android:id="@+id/btn_premium_features"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_centerHorizontal="true"
                    android:layout_marginTop="15dp"
                    android:background="@drawable/img_btn_premium"
                    android:padding="10dp"
                    android:text="@string/premium_features"
                    android:textSize="25sp" />
因为在我得到错误之前,有时我会说我不能在ImageButton上投射Button 但显然我不是

//this is inside a thread
premiumFeaturesBtn.setOnClickListener(new View.OnClickListener() {

它不应该位于除主/UI线程之外的任何其他线程中,在主/UI线程中执行
onCreate

不同设备上的不同行为可能导致使用不同的布局来定义屏幕大小、方向等

检查按钮标识符(
android:id=“@+id/btn\u premium\u features”
)是否已在所有适用的布局中定义


这可以解释为什么它在某些设备上运行,而在其他设备上不运行。

当您在按钮定义中去掉android:background属性时会发生什么?在尝试通过
findviewbyd()初始化小部件之前,确保调用了
setContentView(R.layout.layoutName)
方法
方法。删除背景后,它仍会崩溃。我在onCreate开始时调用setContentView,一切都是在onCreate之后完成的it@DoubleP90请发布您的完整代码,以了解您正在做什么您确定您正在获得NPE吗?如果我将其注释掉或将其移动到主线程,它将崩溃aswell@DoubleP90照普拉格纳尼的建议去做。
premiumFeaturesBtn = (Button) findViewById(R.id.btn_premium_features); 
//this is inside a thread
premiumFeaturesBtn.setOnClickListener(new View.OnClickListener() {