从按钮开始活动的空指针异常

时间:2013-02-09 14:31:17

标签: android nullpointerexception

我正在尝试通过按钮的onClickListener启动一个actvivity,并且我总是得到Null指针异常。 我搜索并尝试了很多不同的东西,我找不到我犯了什么错误。 这是相关的代码/类

崩溃活动:

    public class DisplayData extends Activity{

    TextView displayData;
    DataObjectsProvider provider;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.displaydb);

        provider = new DataObjectsProvider(this);
        displayData = (TextView) findViewById(R.id.tvDisplayData);      
        displayData.setText(provider.getAlldobjects().toString());
    }

}

(我试过推荐了提供者和setText代码)

来自工作主要活动的onClickListener:

bDisplay.setOnClickListener(new OnClickListener(){

        public void onClick(View v) {
            // TODO Auto-generated method stub
             Intent intent = new Intent(MainActivity.this, DisplayData.class);
            startActivity(intent);
        }

    });

以下是崩溃活动的布局:

<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/scrollView1"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" >

    <TextView
       android:id="@+id/tvDisplayData"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="showData"
       android:textAppearance="?android:attr/textAppearanceMedium" />

</ScrollView>

(我已经尝试过,只使用线性布局和textview)

这是Android清单代码:

<activity
        android:name=".MainActivity"
        android:label="@string/title_activity_main" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

   <activity
        android:name=".DisplayData"
        android:label="" >
    </activity>

我做错了吗?是否有任何我没有看到的错误或者我错过了什么?

修改 日志:

  

02-09 23:52:35.002:W / dalvikvm(24849):threadid = 1:线程退出未捕获的异常(group = 0x40c971f8)   02-09 23:52:35.052:E / AndroidRuntime(24849):致命异常:主要   02-09 23:52:35.052:E / AndroidRuntime(24849):java.lang.RuntimeException:无法启动活动ComponentInfo {com.d69.dancesongsdb / com.d69.dancesongsdb.DisplayData}:java.lang.NullPointerException   02-09 23:52:35.052:E / AndroidRuntime(24849):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1956)   02-09 23:52:35.052:E / AndroidRuntime(24849):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)   02-09 23:52:35.052:E / AndroidRuntime(24849):在android.app.ActivityThread.access $ 600(ActivityThread.java:123)   02-09 23:52:35.052:E / AndroidRuntime(24849):在android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1147)   02-09 23:52:35.052:E / AndroidRuntime(24849):在android.os.Handler.dispatchMessage(Handler.java:99)   02-09 23:52:35.052:E / AndroidRuntime(24849):在android.os.Looper.loop(Looper.java:137)   02-09 23:52:35.052:E / AndroidRuntime(24849):在android.app.ActivityThread.main(ActivityThread.java:4424)   02-09 23:52:35.052:E / AndroidRuntime(24849):at java.lang.reflect.Method.invokeNative(Native Method)   02-09 23:52:35.052:E / AndroidRuntime(24849):at java.lang.reflect.Method.invoke(Method.java:511)   02-09 23:52:35.052:E / AndroidRuntime(24849):at com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:787)   02-09 23:52:35.052:E / AndroidRuntime(24849):at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:554)   02-09 23:52:35.052:E / AndroidRuntime(24849):at dalvik.system.NativeStart.main(Native Method)   02-09 23:52:35.052:E / AndroidRuntime(24849):引起:java.lang.NullPointerException   02-09 23:52:35.052:E / AndroidRuntime(24849):at com.d69.dancesongsdb.DataObjectsProvider.getAlldobjects(DataObjectsProvider.java:58)   02-09 23:52:35.052:E / AndroidRuntime(24849):at com.d69.dancesongsdb.DisplayData.onCreate(DisplayData.java:19)   02-09 23:52:35.052:E / AndroidRuntime(24849):在android.app.Activity.performCreate(Activity.java:4465)   02-09 23:52:35.052:E / AndroidRuntime(24849):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)   02-09 23:52:35.052:E / AndroidRuntime(24849):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)   02-09 23:52:35.052:E / AndroidRuntime(24849):... 11更多

EDIT2 我放弃了db4o并用sqlite重新创建了我的类。但是这个错误仍然发生在活动上。我也编辑了崩溃活动的代码。 最新的一行(使用提供者)是引起崩溃的行。我已经在主要活动上测试了它,通过以下代码更改了启动活动的按钮的代码:

public void onClick(View v) {       
    Toast.makeText(MainActivity.this, provider.getAlldobjects().toString(), Toast.LENGTH_LONG).show();

并且数据库的项目在吐司上显示正确。 在主要活动(从上面的代码中)我已经使用与崩溃活动完全相同的方式声明了DataObjectsProvider类。我无法理解为什么一项活动有效,而另一项无效。

DataObjectsProvider:

public class DataObjectsProvider {

  // Database fields
  private SQLiteDatabase database;
  private DbHelper dbHelper;
  private String[] allColumns = { DbHelper.COLUMN_ID,
      DbHelper.COLUMN_SONGNAME, DbHelper.COLUMN_SONGARTIST, DbHelper.COLUMN_SONGGENRE };

  public DataObjectsProvider (Context context) {
        dbHelper = new DbHelper(context);
      }

  public void open() throws SQLException {
        database = dbHelper.getWritableDatabase();
      }

      public void close() {
        dbHelper.close();
      }

      public DataObjects createDataObjects (String songName, String songArtist, String songGenre){
        ContentValues values = new ContentValues();
        values.put(DbHelper.COLUMN_SONGNAME, songName + ", ");
        values.put(DbHelper.COLUMN_SONGARTIST, songArtist + ", ");
        values.put(DbHelper.COLUMN_SONGGENRE, songGenre);
        long insertId = database.insert(DbHelper.TABLE_SONGS, null,
                values);
            Cursor cursor = database.query(DbHelper.TABLE_SONGS,
                allColumns, DbHelper.COLUMN_ID + " = " + insertId, null,
                null, null, null);
            cursor.moveToFirst();
            DataObjects newDobject = cursorToDataObjects(cursor);
            cursor.close();
            return newDobject;

      }

      public void deleteDobjects(DataObjects dobjects) {
            long id = dobjects.getId();
            System.out.println("Comment deleted with id: " + id);
            database.delete(DbHelper.TABLE_SONGS, DbHelper.COLUMN_ID
                + " = " + id, null);
          }

      public List<DataObjects> getAlldobjects() {
            List<DataObjects> dobjects = new ArrayList<DataObjects>();

            Cursor cursor = database.query(DbHelper.TABLE_SONGS,
                allColumns, null, null, null, null, null);

            cursor.moveToFirst();
            while (!cursor.isAfterLast()) {
              DataObjects dobject = cursorToDataObjects(cursor);
              dobjects.add(dobject);
              cursor.moveToNext();
            }
            // Make sure to close the cursor
            cursor.close();
            return dobjects;
          }

    private DataObjects cursorToDataObjects(Cursor cursor) {
        DataObjects dobject = new DataObjects();
        dobject.setId(cursor.getLong(0));
        dobject.setSongName(cursor.getString(1));
        dobject.setSongArtist(cursor.getString(2));
        dobject.setSongGenre(cursor.getString(3));
        return dobject;
    }

}

2 个答案:

答案 0 :(得分:1)

如果没有堆栈跟踪(发布一个),很难看出问题所在。

但从我所看到的情况来看,NPE可能来自这两行中的任何一行:

displayData = (TextView) findViewById(R.id.tvDisplayData);      
displayData.setText(provider.list.toString());

displayData(TextView)为null或提供者列表。您确定要在提供程序的构造函数中创建列表吗?

编辑:

错误发生在DataObjectsProvider的第24行:

"at com.d69.dancesongsdb.DataObjectsProvider.(DataObjectsProvider.java:24)"

EDIT2:

你从未打过电话。因此数据库对象为null。你的崩溃了。您还可以检查从该查询中检索的光标是否为null,然后再对其进行操作。

答案 1 :(得分:0)

最后,搜索和阅读减少了我的愚蠢。我试图在没有先打开数据库的情况下进行查询。在MainActivity上,数据库是从另一个方法调用(存储项目)打开的,但是在DisplayData活动上没有。所以首先需要使用:

provider.open();

然后:

provider.getAllObjects();