Java 尝试启动我的应用程序时出现NullPointerException

Java 尝试启动我的应用程序时出现NullPointerException,java,android,sharedpreferences,logcat,Java,Android,Sharedpreferences,Logcat,我正在尝试运行我的主菜单,它创建了一个SharedReference文件,其中包含一个ArrayList,其中包含字符串和双精度的对象Food。 在尝试运行时,应用程序会崩溃, 这是我的代码: package com.example.davidson; import java.util.ArrayList; import com.google.gson.Gson; import android.support.v7.app.ActionBarActivity; import android

我正在尝试运行我的主菜单,它创建了一个
SharedReference
文件,其中包含一个
ArrayList
,其中包含字符串和双精度的对象Food。 在尝试运行时,应用程序会崩溃, 这是我的代码:

package com.example.davidson;

import java.util.ArrayList;

import com.google.gson.Gson;

import android.support.v7.app.ActionBarActivity;
import android.support.v4.app.Fragment;
import android.content.Intent;
import android.content.SharedPreferences;
import android.content.SharedPreferences.Editor;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.Button;

public class MainMenu extends ActionBarActivity implements OnClickListener {
Button btn1,btn2,btn3,btn4;
public ArrayList<Food>L=new ArrayList<Food>();
public static String filename="mySharedList";
SharedPreferences myFoodList;
public Editor editor=myFoodList.edit();

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main_menu);    
    myFoodList=getSharedPreferences(filename,0);
    btn1=(Button)findViewById(R.id.button1);
    btn2=(Button)findViewById(R.id.button2);
    btn3=(Button)findViewById(R.id.button3);
    btn4=(Button)findViewById(R.id.button4);
    btn1.setOnClickListener(this);
    btn2.setOnClickListener(this);
    btn3.setOnClickListener(this);
    btn4.setOnClickListener(this);
    Createfoods();



}

@Override
public boolean onCreateOptionsMenu(Menu menu) {

    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main_menu, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();
    if (id == R.id.action_settings) {
        return true;
    }
    return super.onOptionsItemSelected(item);
}

/**
 * A placeholder fragment containing a simple view.
 */
public static class PlaceholderFragment extends Fragment {

    public PlaceholderFragment() {
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        View rootView = inflater.inflate(R.layout.fragment_main_menu,
                container, false);
        return rootView;
    }
}

@Override
public void onClick(View v) {
    if(v.getId()==R.id.button1)
    {
        Intent openFoodSearch=new      Intent("com.example.davidson.FOODSEARCH");
        startActivity(openFoodSearch);
    }
    if(v.getId()==R.id.button2)
    {
        Intent openMyList=new Intent("com.example.davidson.MY_LIST");
        startActivity(openMyList);
    }
    if(v.getId()==R.id.button3)
    {
        Intent openRecommended=new     Intent("com.example.davidson.RECOMMENDED");
        startActivity(openRecommended);
    }
    if(v.getId()==R.id.button4)
    {
        Intent openAddItem=new Intent("com.example.davidson.ADDITEM");
        startActivity(openAddItem);
    }

    }
public void Createfoods()
{
Food f1=new Food("cucumber",50,5,4,3);
Food f2=new Food("tomato",50,3,2,1);
L.add(f1);
L.add(f2);
Gson gson=new Gson();
String json=gson.toJson(L);
editor.putString("myShardList",json);
editor.commit();

}
}
package com.example.davidson;
导入java.util.ArrayList;
导入com.google.gson.gson;
导入android.support.v7.app.ActionBarActivity;
导入android.support.v4.app.Fragment;
导入android.content.Intent;
导入android.content.SharedReferences;
导入android.content.SharedReferences.Editor;
导入android.os.Bundle;
导入android.view.LayoutInflater;
导入android.view.Menu;
导入android.view.MenuItem;
导入android.view.view;
导入android.view.view.OnClickListener;
导入android.view.ViewGroup;
导入android.widget.Button;
公共类主菜单扩展ActionBarActivity实现OnClickListener{
按钮btn1、btn2、btn3、btn4;
public ArrayListL=new ArrayList();
公共静态字符串filename=“mySharedList”;
共享参考myFoodList;
public Editor=myFoodList.edit();
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity\u主菜单);
myFoodList=GetSharedReferences(文件名,0);
btn1=(按钮)findViewById(R.id.button1);
btn2=(按钮)findViewById(R.id.button2);
btn3=(按钮)findViewById(R.id.button3);
btn4=(按钮)findViewById(R.id.button4);
btn1.setOnClickListener(此);
btn2.setOnClickListener(此);
btn3.setOnClickListener(此);
btn4.setOnClickListener(此);
Createfoods();
}
@凌驾
公共布尔onCreateOptions菜单(菜单){
//为菜单充气;这会将项目添加到操作栏(如果存在)。
getMenuInflater().充气(右菜单.主菜单,菜单);
返回true;
}
@凌驾
公共布尔值onOptionsItemSelected(菜单项项){
//处理操作栏项目单击此处。操作栏将
//自动处理Home/Up按钮上的点击,只要
//在AndroidManifest.xml中指定父活动时。
int id=item.getItemId();
if(id==R.id.action\u设置){
返回true;
}
返回super.onOptionsItemSelected(项目);
}
/**
*包含简单视图的占位符片段。
*/
公共静态类占位符片段扩展了片段{
公共占位符片段(){
}
@凌驾
创建视图上的公共视图(布局、充气机、视图组容器、,
Bundle savedInstanceState){
视图根视图=充气机。充气(R.layout.fragment\u主菜单,
货柜(虚假);;
返回rootView;
}
}
@凌驾
公共void onClick(视图v){
如果(v.getId()==R.id.button1)
{
Intent openFoodSearch=newintent(“com.example.davidson.FOODSEARCH”);
startActivity(openFoodSearch);
}
如果(v.getId()==R.id.button2)
{
Intent openMyList=newintent(“com.example.davidson.MY_LIST”);
星触觉(openMyList);
}
如果(v.getId()==R.id.button3)
{
Intent openRecommended=newintent(“com.example.davidson.RECOMMENDED”);
起始触觉(推荐);
}
如果(v.getId()==R.id.button4)
{
Intent openAddItem=newintent(“com.example.davidson.ADDITEM”);
startActivity(openAddItem);
}
}
公共食品
{
食品f1=新食品(“黄瓜”,50,5,4,3);
食品f2=新食品(“番茄”,50,3,2,1);
L.添加(f1);
L.添加(f2);
Gson Gson=新的Gson();
字符串json=gson.toJson(L);
putString(“mysharlist”,json);
commit();
}
}
下面是日志

Shutting down VM
   threadid=1: thread exiting with uncaught exception (group=0xb3a87ba8)
    FATAL EXCEPTION: main
   Process: com.example.davidson, PID: 1157
    java.lang.RuntimeException: Unable to instantiate activity           ComponentInfo{com.example.davidson/com.example.davidson.MainMenu}:     java.lang.NullPointerException
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2121)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
    at android.app.ActivityThread.access$800(ActivityThread.java:135)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:136)
    at android.app.ActivityThread.main(ActivityThread.java:5017)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:515)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
    at dalvik.system.NativeStart.main(Native Method)
       Caused by: java.lang.NullPointerException
    at com.example.davidson.MainMenu.<init>(MainMenu.java:26)
    at java.lang.Class.newInstanceImpl(Native Method)
    at java.lang.Class.newInstance(Class.java:1208)
    at android.app.Instrumentation.newActivity(Instrumentation.java:1061)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2112)
    ... 11 more
       Sending signal. PID: 1157 SIG: 9
关闭虚拟机
threadid=1:线程以未捕获异常退出(组=0xb3a87ba8)
致命异常:主
进程:com.example.davidson,PID:1157
java.lang.RuntimeException:无法实例化活动组件信息{com.example.davidson/com.example.davidson.MainMenu}:java.lang.NullPointerException
在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2121)上
位于android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
在android.app.ActivityThread.access$800(ActivityThread.java:135)
在android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)上
位于android.os.Handler.dispatchMessage(Handler.java:102)
位于android.os.Looper.loop(Looper.java:136)
位于android.app.ActivityThread.main(ActivityThread.java:5017)
位于java.lang.reflect.Method.Invokenactive(本机方法)
位于java.lang.reflect.Method.invoke(Method.java:515)
在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)上
位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
在dalvik.system.NativeStart.main(本机方法)
原因:java.lang.NullPointerException
在com.example.davidson.MainMenu.(MainMenu.java:26)
位于java.lang.Class.newInstanceImpl(本机方法)
位于java.lang.Class.newInstance(Class.java:1208)
位于android.app.Instrumentation.newActivity(Instrumentation.java:1061)
在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2112)上
... 还有11个
发送信号。PID:1157信号:9

由于以下几行代码,您将得到一个
NullPointerException

SharedPreferences myFoodList;
public Editor editor=myFoodList.edit();
Caused by: java.lang.NullPointerException
  at com.example.davidson.MainMenu.<init>(MainMenu.java:26)
您还不能调用
myFoodList
edit()
函数,因为它尚未初始化且为
null
。您需要在调用它之前对其进行初始化,最好是在
onCreate()
函数中

您可以通过查看Logcat输出,特别是以下几行来了解这一点:

SharedPreferences myFoodList;
public Editor editor=myFoodList.edit();
Caused by: java.lang.NullPointerException
  at com.example.davidson.MainMenu.<init>(MainMenu.java:26)
原因:java.lang.NullPointerException
在com.example.davidson.MainMenu.(MainMenu.java:26)

logcat告诉您,您的问题出现在主菜单的第26行。java

以及您得到的错误是什么?请发布堆栈跟踪和您得到的错误。忘记添加logcat了,是吗:)您在哪一行得到
NPE