【发布时间】:2015-04-26 16:05:45
【问题描述】:
我正在开发我的第一个 android 项目,我正在使用 android studio。该项目在我的测试设备上运行良好,然后我选择清理项目,现在应用程序无法运行,抛出的异常是:
Unable to instantiate activity
ComponentInfo{com.lonerganonline.league_of_ireland/com.lonerganonline.league_of_ireland.MainActivity}:
java.lang.NullPointerException
因为我不知道错误出在哪里,所以我不知道要发布什么代码。
主要活动:
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.access$800(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)
【问题讨论】:
-
请添加您的 MainActivity 代码
-
请发布 MainActivity
-
检查 logcat 输出以获得完整的堆栈跟踪,它将与您的
MainActivity代码对齐并指出问题所在。如果您同时发布完整的 logcat 输出和MainActivity代码,这里的人可能会很快提供帮助。 -
favTeam很可能为空 -
在初始化
editor之后初始化favTeam
标签: android android-activity android-studio nullpointerexception fatal-error