【发布时间】: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。这就是您的应用崩溃的原因。