使用 android 共享首选项的致命错误
fatal error using android shared preference
我正在做我的第一个 android 项目,我正在使用 android 工作室。该项目在我的测试设备上 运行ning 正常,然后我选择清理项目,现在应用程序不会 运行,抛出的异常是:
Unable to instantiate activity
ComponentInfo{com.lonerganonline.league_of_ireland/com.lonerganonline.league_of_ireland.MainActivity}:
java.lang.NullPointerException
因为我不知道错误发生在哪里,所以我不知道 post 的代码是什么。
主要Activity:
package com.lonerganonline.league_of_ireland;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.Spinner;
import android.widget.TextView;
public class MainActivity extends ActionBarActivity {
private Spinner spinner;
private SharedPreferences favTeam ;
private SharedPreferences.Editor editor;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
favTeam = this.getSharedPreferences("com.lonerganonline.league_of_ireland", Context.MODE_PRIVATE);
/*if (favTeam.contains("team")){
setContentView(R.layout.my_home);
}
else{*/
setContentView(R.layout.activity_main);
// }
spinner = (Spinner) findViewById(R.id.selectTeam);
ArrayAdapter<CharSequence> adapter = ArrayAdapter.createFromResource(this, R.array.teams_array, android.R.layout.simple_spinner_item);
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
spinner.setAdapter(adapter);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}
public String getTeam(){
String team ="";
favTeam.getString("team","Not Defined");
return team;
}
@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();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
public void submitMyTeam(View v){
TextView txt = (TextView) findViewById(R.id.textView);
String selectedTeam = spinner.getSelectedItem().toString();
txt.setText(selectedTeam);
editor = favTeam.edit();
editor.putString("team", selectedTeam);
editor.apply();
Intent intent = new Intent(this, MyTeamActivity.class);
startActivity(intent);
}
}
<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:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">
<Spinner
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/selectTeam"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:layout_marginTop="163dp" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/submit"
android:id="@+id/button"
android:onClick="submitMyTeam"
android:layout_below="@+id/selectTeam"
android:layout_centerHorizontal="true" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceLarge"
android:id="@+id/textView"
android:layout_above="@+id/selectTeam"
android:layout_centerHorizontal="true" />
</RelativeLayout>
Logcat
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.lonerganonline.league_of_ireland/com.lonerganonline.league_of_ireland.MainActivity}: java.lang.NullPointerException
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2163)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2286)
at android.app.ActivityThread.access0(ActivityThread.java:144)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1246)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:212)
at android.app.ActivityThread.main(ActivityThread.java:5137)
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:902)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:718)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at com.lonerganonline.league_of_ireland.MainActivity.<init>(MainActivity.java:19)
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:2154)
这样的近似错误我只在布局inflation时出现空指针异常时见过。此类错误的最简单形式是尝试在 onCreate 中设置诸如侦听器或菜单之类的任何内容。发生这种情况是因为当您说 "set fragment" 之类的内容时,您并没有真正加载该片段。您在队列中的某处添加充气机作业。您不能保证所有布局都在 onCreate 结束时设置。
我敢打赌将它移到应用程序启动流程的后面(尝试 onStart() )
ArrayAdapter<CharSequence> adapter = ArrayAdapter.createFromResource(this, R.array.teams_array, android.R.layout.simple_spinner_item);
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
spinner.setAdapter(adapter);move this
私人 SharedPreferences.Editor 编辑 = favTeam.edit();
改变private SharedPreferences.Editor editor = favTeam.edit();
至 private SharedPreferences.Editor editor;
它会导致 NullPointerException,因为它会在构造 Activity 对象时尝试初始化编辑器,但在执行 onCreate()
之前执行 favTeam
class 成员。
然后在方法 onCreate()
中添加下一行
editor = favTeam.edit();
在你之后
favTeam = this.getSharedPreferences("com.lonerganonline.league_of_ireland", Context.MODE_PRIVATE);
我正在做我的第一个 android 项目,我正在使用 android 工作室。该项目在我的测试设备上 运行ning 正常,然后我选择清理项目,现在应用程序不会 运行,抛出的异常是:
Unable to instantiate activity
ComponentInfo{com.lonerganonline.league_of_ireland/com.lonerganonline.league_of_ireland.MainActivity}:
java.lang.NullPointerException
因为我不知道错误发生在哪里,所以我不知道 post 的代码是什么。
主要Activity:
package com.lonerganonline.league_of_ireland;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.Spinner;
import android.widget.TextView;
public class MainActivity extends ActionBarActivity {
private Spinner spinner;
private SharedPreferences favTeam ;
private SharedPreferences.Editor editor;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
favTeam = this.getSharedPreferences("com.lonerganonline.league_of_ireland", Context.MODE_PRIVATE);
/*if (favTeam.contains("team")){
setContentView(R.layout.my_home);
}
else{*/
setContentView(R.layout.activity_main);
// }
spinner = (Spinner) findViewById(R.id.selectTeam);
ArrayAdapter<CharSequence> adapter = ArrayAdapter.createFromResource(this, R.array.teams_array, android.R.layout.simple_spinner_item);
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
spinner.setAdapter(adapter);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}
public String getTeam(){
String team ="";
favTeam.getString("team","Not Defined");
return team;
}
@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();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
public void submitMyTeam(View v){
TextView txt = (TextView) findViewById(R.id.textView);
String selectedTeam = spinner.getSelectedItem().toString();
txt.setText(selectedTeam);
editor = favTeam.edit();
editor.putString("team", selectedTeam);
editor.apply();
Intent intent = new Intent(this, MyTeamActivity.class);
startActivity(intent);
}
}
<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:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">
<Spinner
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/selectTeam"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:layout_marginTop="163dp" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/submit"
android:id="@+id/button"
android:onClick="submitMyTeam"
android:layout_below="@+id/selectTeam"
android:layout_centerHorizontal="true" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceLarge"
android:id="@+id/textView"
android:layout_above="@+id/selectTeam"
android:layout_centerHorizontal="true" />
</RelativeLayout>
Logcat
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.lonerganonline.league_of_ireland/com.lonerganonline.league_of_ireland.MainActivity}: java.lang.NullPointerException
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2163)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2286)
at android.app.ActivityThread.access0(ActivityThread.java:144)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1246)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:212)
at android.app.ActivityThread.main(ActivityThread.java:5137)
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:902)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:718)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at com.lonerganonline.league_of_ireland.MainActivity.<init>(MainActivity.java:19)
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:2154)
这样的近似错误我只在布局inflation时出现空指针异常时见过。此类错误的最简单形式是尝试在 onCreate 中设置诸如侦听器或菜单之类的任何内容。发生这种情况是因为当您说 "set fragment" 之类的内容时,您并没有真正加载该片段。您在队列中的某处添加充气机作业。您不能保证所有布局都在 onCreate 结束时设置。
我敢打赌将它移到应用程序启动流程的后面(尝试 onStart() )
ArrayAdapter<CharSequence> adapter = ArrayAdapter.createFromResource(this, R.array.teams_array, android.R.layout.simple_spinner_item);
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
spinner.setAdapter(adapter);move this
私人 SharedPreferences.Editor 编辑 = favTeam.edit();
改变private SharedPreferences.Editor editor = favTeam.edit();
至 private SharedPreferences.Editor editor;
它会导致 NullPointerException,因为它会在构造 Activity 对象时尝试初始化编辑器,但在执行 onCreate()
之前执行 favTeam
class 成员。
然后在方法 onCreate()
中添加下一行
editor = favTeam.edit();
在你之后
favTeam = this.getSharedPreferences("com.lonerganonline.league_of_ireland", Context.MODE_PRIVATE);