Android Null指针异常onCreate

时间:2014-02-28 06:39:04

标签: java android xml nullpointerexception oncreate

所以我只是学习编写Android应用程序,没有什么特别的,但主要是四处寻找,看看它们是如何工作的。我试图在操作栏中根据我发现的教程做一些标签,但是在应用程序启动之前我得到了一个空指针异常。

以下是代码:

@Override
protected void onCreate(Bundle savedInstanceState) 
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    viewPager = (ViewPager) findViewById(R.id.pager);
    actionBar = getActionBar();
    mAdapter = new TabsPagerAdapter(getSupportFragmentManager());

    viewPager.setAdapter(mAdapter);
    actionBar.setHomeButtonEnabled(false);
    actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);

    for(String tab_names : tabs)
    {
        actionBar.addTab(actionBar.newTab().setText(tab_names).setTabListener(this));
    }

    viewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener()
    {
        @Override
        public void onPageSelected(int position)
        {
            actionBar.setSelectedNavigationItem(position);
        }

        @Override
        public void onPageScrolled(int arg0,float arg1,int arg2)
        {

        }

        @Override
        public void onPageScrollStateChanged(int arg0)
        {

        }
    });
}

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) 
{

    View rootView = inflater.inflate(R.layout.web_fragment, container, false);

    return rootView;
}

onCreateView还有另外两个具有不同布局的类,但完全相同。这是xml,第一个是片段的主要和下一个:

<android.support.v4.view.ViewPager    xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="match_parent"/>



<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:orientation="vertical"
android:background="#ff8400">

<TextView
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:gravity="center"
    android:text="@string/hello_world"
    android:textSize="20sp"
    android:layout_centerInParent="true"/>

我似乎无法弄清楚导致抛出异常的原因。我似乎也无法将logcat导出到日志文件中,因此我也会尝试在此处进行操作。

logcat的

 02-28 01:36:42.431: I/Process(1629): Sending signal. PID: 1629 SIG: 9

   02-28 01:37:27.401: D/AndroidRuntime(1668): Shutting down VM

   02-28 01:37:27.401: W/dalvikvm(1668): threadid=1: thread exiting with uncaught exception (group=0xb4a1fb90)

   02-28 01:37:27.471: E/AndroidRuntime(1668): FATAL EXCEPTION: main

   02-28 01:37:27.471: E/AndroidRuntime(1668): Process: com.example.tolerablenausea, PID: 1668

   02-28 01:37:27.471: E/AndroidRuntime(1668): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.tolerablenausea/com.example.tolerablenausea.MainActivity}: java.lang.NullPointerException

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2102)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2226)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at android.app.ActivityThread.access$700(ActivityThread.java:135)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1397)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at android.os.Handler.dispatchMessage(Handler.java:102)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at android.os.Looper.loop(Looper.java:137)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at android.app.ActivityThread.main(ActivityThread.java:4998)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at java.lang.reflect.Method.invokeNative(Native Method)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at java.lang.reflect.Method.invoke(Method.java:515)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
   02-28 01:37:27.471: E/AndroidRuntime(1668):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at dalvik.system.NativeStart.main(Native Method)

   02-28 01:37:27.471: E/AndroidRuntime(1668): Caused by: java.lang.NullPointerException

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at android.content.ContextWrapper.getResources(ContextWrapper.java:89)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at android.view.ContextThemeWrapper.getResources(ContextThemeWrapper.java:78)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at android.content.Context.getString(Context.java:343)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at com.example.tolerablenausea.MainActivity.<init>(MainActivity.java:29)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at java.lang.Class.newInstanceImpl(Native Method)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at java.lang.Class.newInstance(Class.java:1208)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at android.app.Instrumentation.newActivity(Instrumentation.java:1061)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2093)

   02-28 01:37:27.471: E/AndroidRuntime(1668):  ... 11 more

2 个答案:

答案 0 :(得分:1)

如果使用了每个循环,则无法看到正在初始化的“标签”。如果它为null并且其中没有“String”。

检查:
如果你的android:minSdkVersion设置为8(API-8),它不提供getActionBar()(仅限API-11)。

如果抑制了lint警告,则不会出现编译时错误。

尝试http://actionbarsherlock.com/ - 向后兼容性有帮助。

如果你想检查, 看看是否有效:

if (android.os.Build.VERSION.SDK_INT >= 11)
    getActionBar().setDisplayHomeAsUpEnabled(true);

答案 1 :(得分:0)

我认为getActionbar()方法返回null值,您可以按照下面提供的链接。

NullPointException with getActionBar

getActionBar() returns null

它可能对你有所帮助。 如果它对您有帮助,请标记为答案。