onCreate中的Android崩溃
每当我运行我的应用程序时,第一次从Eclipse运行它时,它运行良好。但是如果我关闭应用程序并重新打开它,它将在onCreate上崩溃。以下是日志:onCreate中的Android崩溃,android,eclipse,crash,nullpointerexception,logcat,Android,Eclipse,Crash,Nullpointerexception,Logcat,每当我运行我的应用程序时,第一次从Eclipse运行它时,它运行良好。但是如果我关闭应用程序并重新打开它,它将在onCreate上崩溃。以下是日志: 10-10 02:50:00.665: E/AndroidRuntime(29564): FATAL EXCEPTION: main 10-10 02:50:00.665: E/AndroidRuntime(29564): java.lang.RuntimeException: Unable to start activity ComponentI
10-10 02:50:00.665: E/AndroidRuntime(29564): FATAL EXCEPTION: main
10-10 02:50:00.665: E/AndroidRuntime(29564): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.appuccino.unitconverter/com.appuccino.unitconverter.MainActivity}: java.lang.NullPointerException
10-10 02:50:00.665: E/AndroidRuntime(29564): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2100)
10-10 02:50:00.665: E/AndroidRuntime(29564): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2125)
10-10 02:50:00.665: E/AndroidRuntime(29564): at android.app.ActivityThread.access$600(ActivityThread.java:140)
10-10 02:50:00.665: E/AndroidRuntime(29564): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1227)
10-10 02:50:00.665: E/AndroidRuntime(29564): at android.os.Handler.dispatchMessage(Handler.java:99)
10-10 02:50:00.665: E/AndroidRuntime(29564): at android.os.Looper.loop(Looper.java:137)
10-10 02:50:00.665: E/AndroidRuntime(29564): at android.app.ActivityThread.main(ActivityThread.java:4898)
10-10 02:50:00.665: E/AndroidRuntime(29564): at java.lang.reflect.Method.invokeNative(Native Method)
10-10 02:50:00.665: E/AndroidRuntime(29564): at java.lang.reflect.Method.invoke(Method.java:511)
10-10 02:50:00.665: E/AndroidRuntime(29564): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1008)
10-10 02:50:00.665: E/AndroidRuntime(29564): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:775)
10-10 02:50:00.665: E/AndroidRuntime(29564): at dalvik.system.NativeStart.main(Native Method)
10-10 02:50:00.665: E/AndroidRuntime(29564): Caused by: java.lang.NullPointerException
10-10 02:50:00.665: E/AndroidRuntime(29564): at com.appuccino.unitconverter.MainActivity.onCreate(MainActivity.java:37)
10-10 02:50:00.665: E/AndroidRuntime(29564): at android.app.Activity.performCreate(Activity.java:5206)
10-10 02:50:00.665: E/AndroidRuntime(29564): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094)
10-10 02:50:00.665: E/AndroidRuntime(29564): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2064)
10-10 02:50:00.665: E/AndroidRuntime(29564): ... 11 more
我主要活动的第一部分:
public class MainActivity extends FragmentActivity implements
OnItemSelectedListener {
/**
* The serialization (saved instance state) Bundle key representing the
* current dropdown position.
*/
private static final String STATE_SELECTED_NAVIGATION_ITEM = "selected_navigation_item";
private Spinner firstSpinner;
private Spinner secondSpinner;
final String[] mainCategoryChoices = {"Acceleration", "Angles", "Area", "Astronomical", "Clothing", "Computers and Electronics", "Cooking", "Date/Time", "Density", "Energy"};
final String[] subCategoryChoices = {"Acre", "Barn", "Bunder", "Hundred", "Jerib", "Kappland", "Labor", "Ping", "Rai", "Shed", "Sitio", "Square", "Square Mile", "Square Yard"};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
getWindow().requestFeature(Window.FEATURE_ACTION_BAR); //not necessary
setContentView(R.layout.activity_main);
ArrayAdapter<String> firstAdapter = new ArrayAdapter<String>(
MainActivity.this, android.R.layout.simple_dropdown_item_1line,
mainCategoryChoices);
ArrayAdapter<String> secondAdapter = new ArrayAdapter<String>(
MainActivity.this, android.R.layout.simple_dropdown_item_1line,
subCategoryChoices);
final ActionBar actionBar = getActionBar();
if(actionBar != null)
{
actionBar.setCustomView(R.layout.action_bar_custom);
actionBar.setDisplayShowTitleEnabled(false);
actionBar.setDisplayShowCustomEnabled(true);
actionBar.setDisplayUseLogoEnabled(false);
actionBar.setDisplayShowHomeEnabled(false);
}
firstSpinner = (Spinner) findViewById(R.id.firstSpinner);
secondSpinner = (Spinner) findViewById(R.id.secondSpinner);
firstSpinner.setAdapter(firstAdapter);
secondSpinner.setAdapter(secondAdapter);
firstSpinner.setOnItemSelectedListener(this);
secondSpinner.setOnItemSelectedListener(this);
}
虽然当我单击它时,它会进入onCreate()上方的一行,但是什么导致它崩溃?我打赌
NPE
就在这一行-
getWindow().requestFeature(Window.FEATURE_ACTION_BAR);
根据文档,该方法仍有可能在onCreate
内返回null
。如果该行不是注释中所述的必需行,请尝试将其删除
另外,您应该仔细检查您的
activity\u main
布局是否包含视图firstSpinner
和secondSpinner
第37行似乎存在空指针异常:secondSpinner=(Spinner)findViewById(R.id.secondSpinner)代码>
苏,你应该检查你的布局
是否包含此微调器
我最终在和的帮助下解决了问题,我使用的是包含微调器的自定义actionBar布局,activity\u main只是一个用于显示片段的框架布局,因此,我使用的布局上下文中不存在这两个微调器。LogCat指向特定的行。它说异常正在第37行抛出。Logcat指向com.appuccino.unitconverter.MainActivity.onCreate(MainActivity.java:37)
上的。那里有一个NPE。告诉我们这是哪一行,我们可能会提供更准确的帮助。请始终在堆栈跟踪中查找由
行引起的,该行告诉您错误发生的原因和位置。对此,我编辑了原始帖子,并在底部添加了第37行是子类别选择[],虽然当我双击它时,它会将我引向onCreate()上方的那一行,显然你是通过计算行数得出这一结论的,但肯定OP有import
语句和package
名称,因此第37行会进一步向下。此外,这不会导致出现NPE
,但以后可能会出现。是的,很抱歉我做了一次编辑,codeMagic是正确的,因为它实际上更高,因为有导入数据,它位于创建子类别选项和onCreate()之间
getWindow().requestFeature(Window.FEATURE_ACTION_BAR);