初学者Java / Android开发人员。我知道这是一个令人难以置信的过度问题,但我从其他所有线程中尝试过的所有内容都无法解决。无论。要么它将返回null,要么根本不工作并在获取SharedPreferences对象的行上抛出错误。如果这只是一个非常小的错误,请道歉。
完整堆栈跟踪和下面的代码。
05-03 20:35:38.225 18928-18928/com.example.admin2.clicker E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.admin2.clicker, PID: 18928
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.admin2.clicker/com.example.admin2.clicker.Home}: java.lang.NullPointerException: Attempt to invoke interface method 'android.content.SharedPreferences$Editor android.content.SharedPreferences.edit()' on a null object reference
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2327)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)
at android.app.ActivityThread.-wrap11(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
Caused by: java.lang.NullPointerException: Attempt to invoke interface method 'android.content.SharedPreferences$Editor android.content.SharedPreferences.edit()' on a null object reference
at com.example.admin2.clicker.Home.<init>(Home.java:50)
at java.lang.Class.newInstance(Native Method)
at android.app.Instrumentation.newActivity(Instrumentation.java:1067)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2317)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)
at android.app.ActivityThread.-wrap11(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
代码:
// Used to fetch SharedPreferences object
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_home);
TextView xpText = (TextView) findViewById(R.id.xpText);
TextView lvText = (TextView) findViewById(R.id.lvText);
xpText.setText("Experience: 0/100");
lvText.setText("Level 1");
gameData = this.getSharedPreferences("gameData", MODE_PRIVATE);
}
// The line throwing the error + its context
{
//boolean firstRun = gameData.getBoolean("f", false);
boolean firstRun = true;
if (firstRun) {
SharedPreferences.Editor e = gameData.edit();
e.putInt("xp", 0);
e.putInt("mxp", 100);
e.putInt("lv", 1);
e.putInt("$", 0);
e.putInt("$c", 0);
e.apply();
}
}
如果您有任何疑问或需要更多信息,请与我们联系。我不确定我需要提供的一切。感谢。
答案 0 :(得分:0)
试试这个,你必须声明文件以保存你的数据,之后你只能编辑它。
SharedPreferences pref;
SharedPreferences.Editor editor;
pref = getSharedPreferences("MyPref", 0); // 0 - for private mode
editor = pref.edit();
我使用commit()来更新我想要保存在SharedPreferences中的任何数据。就像你的情况一样
editor.putInt("xp", 0);
editor.putInt("mxp", 100);
editor.putInt("lv", 1);
editor.putInt("$", 0);
editor.putInt("$c", 0);
editor.commit();
我希望这会对你有所帮助。感谢。
答案 1 :(得分:0)
您在initializer block中添加了代码块以编辑首选项,这意味着它将在onCreate()
之前运行,您实际为gameData
分配值NullpointerException
。这就是导致Activity
。
通常,在调用onCreate()
之前,您通常不应对Context
执行任何操作。特别是如果您正在做的事情需要onCreate()
,例如处理偏好时。
要解决此问题,只需在将值分配给gameData
后,将初始化程序块中的代码移至weak
方法。