onCreate中的Android崩溃

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

每当我运行我的应用程序时,第一次从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 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);