【问题标题】:Android Shared Preferences CrashesAndroid 共享首选项崩溃
【发布时间】:2017-03-18 20:23:43
【问题描述】:

当我将它放入手机调试时,此活动崩溃,我只是添加了用于存储变量的部分。我是不是做错了什么?

它是一个活动,如果他们之前设置它们应该得到当前变量,并且用户也可以设置它们。

package com.software.roux.diabcalc;

import android.content.Intent;
import android.content.SharedPreferences;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.PrintWriter;

import static com.software.roux.diabcalc.R.id.bolus;

public class Settings extends AppCompatActivity {

    SharedPreferences mPrefs = getSharedPreferences("label", 0);

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_settings);
        setTitle("Insulin Calculator by Ben Roux");

        String bolusString = mPrefs.getString("bolus", "0");
        String corrString = mPrefs.getString("correction", "0");
        String lowString = mPrefs.getString("low", "0");
        String highString = mPrefs.getString("high", "0");

        EditText b1 = (EditText)findViewById(R.id.bolus);
        b1.setText(bolusString);

        EditText b2 = (EditText)findViewById(R.id.correction);
        b2.setText(corrString);

        EditText b3 = (EditText)findViewById(R.id.targetlow);
        b3.setText(lowString);

        EditText b4 = (EditText)findViewById(R.id.targethigh);
        b4.setText(highString);
    }

    public void switchclick(View a) {
        if (a.getId() == R.id.backbutton) {
            Intent myIntent = new Intent(Settings.this, MainActivity.class);
            Settings.this.startActivity(myIntent);
        }
    }

    public void setclick(View b) {
        if (b.getId() == R.id.setter) {

            EditText b1 = (EditText)findViewById(R.id.bolus);
            String bolussave = ""+b1;
            SharedPreferences.Editor mEditor1 = mPrefs.edit();
            mEditor1.putString("bolus", bolussave).commit();

            EditText b2 = (EditText)findViewById(R.id.correction);
            String corrsave = ""+b2;
            SharedPreferences.Editor mEditor2 = mPrefs.edit();
            mEditor2.putString("correction", corrsave).commit();


            EditText b3 = (EditText)findViewById(R.id.targetlow);
            String lowsave = ""+b3;
            SharedPreferences.Editor mEditor3 = mPrefs.edit();
            mEditor3.putString("low", lowsave).commit();


            EditText b4 = (EditText)findViewById(R.id.targethigh);
            String highsave = ""+b4;
            SharedPreferences.Editor mEditor4 = mPrefs.edit();
            mEditor4.putString("high", highsave).commit();


        }
    }
}

更新崩溃日志:

03-18 15:29:59.477 7801-7801/com.software.roux.diabcalc E/AndroidRuntime: 致命异常: main 进程:com.software.roux.diabcalc,PID:7801 java.lang.RuntimeException:无法实例化活动 组件信息{com.software.roux.diabcalc/com.software.roux.diabcalc.Settings}: java.lang.NullPointerException:尝试调用虚拟方法 'android.content.SharedPreferences android.content.Context.getSharedPreferences(java.lang.String, int)' 在空对象引用上 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3094) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3350) 在 android.app.ActivityThread.access$1100(ActivityThread.java:222) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1795) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java:158) 在 android.app.ActivityThread.main(ActivityThread.java:7229) 在 java.lang.reflect.Method.invoke(本机方法) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120) 引起:java.lang.NullPointerException:尝试调用虚拟 方法'android.content.SharedPreferences android.content.Context.getSharedPreferences(java.lang.String, int)' 在空对象引用上 在 android.content.ContextWrapper.getSharedPreferences(ContextWrapper.java:185) 在 com.software.roux.diabcalc.Settings.(Settings.java:21) 在 java.lang.Class.newInstance(本机方法) 在 android.app.Instrumentation.newActivity(Instrumentation.java:1095) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3084) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3350) 在 android.app.ActivityThread.access$1100(ActivityThread.java:222) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1795) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java:158) 在 android.app.ActivityThread.main(ActivityThread.java:7229) 在 java.lang.reflect.Method.invoke(本机方法) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)

【问题讨论】:

  • 能否提供崩溃日志?
  • 他们会在哪里?使用安卓工作室。
  • 如果您在连接的设备或模拟器上运行程序,您可以在 logcat 中看到日志。在您的 Android Studio 底部栏中搜索“Android Monitor”。
  • 你把“bolus”、“correction”、“low”字符串放在哪里了?在任何其他活动中?因为您在这里尝试在 putString 之前获取 getString。这就是您的应用崩溃的原因。

标签: java android


【解决方案1】:

稍后再启动SharedPreferences mPrefs。在onCreate 方法中。

context 仅在 onCreate 方法之后初始化。 所以,这必须工作:

SharedPreferences mPrefs;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_settings);
        setTitle("Insulin Calculator by Ben Roux");
 mPrefs= getSharedPreferences("label", 0);

作为另一个问题,在您当前的代码中,您只需将EditText 变量的地址保存在内存中。要检索文本,请使用:

String bolussave = ""+b1.getText().toString();

【讨论】:

  • 我解决了这个问题,现在我有一个单独的问题。最初变量为 0,但在我设置它们后,关闭应用程序并重新打开它,它们显示“android.support.v7.widget...app:id/targethigh”这是参考 id 而不是值?我将如何转换为实际值?
【解决方案2】:

尝试在 OnCreate 方法中实例化您的 mPref。

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_settings);
    setTitle("Insulin Calculator by Ben Roux");

    String bolusString = mPrefs.getString("bolus", "0");
    mPrefs = getSharedPreferences("label", 0);
    ...
    ...

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-02-16
    • 1970-01-01
    • 1970-01-01
    • 2018-02-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多