java - 表名=空; NullPointerException 传送结果失败 ResultInfo{who=null, request=1, result=-1, data=Intent

标签 java android sqlite

我在检查表格中的记录并将其与所说的单词进行比较时遇到问题。我正在开发一款类似文字转折的游戏。

变量 randomWordrandom() 方法的结果。数据库中的单词在显示给用户之前必须随机化,并且不应重复一个 session 。

顺便说一句,我的问题是 exists() 方法;发生 NullPointerException,看起来是因为表名是 null

我该怎么办?

exists()random() 方法

 public boolean exists(String word) { 
         Cursor cursor = null;

         String WORD_TABLE = randomWord;
         System.out.println("exists: "+randomWord);
         String [] selectionArgs = {word + "%"};

         cursor = db.rawQuery("SELECT * from "+ WORD_TABLE + "WHERE Word like ?", selectionArgs);

        boolean exists = (cursor.getCount() > 0);

        cursor.close();

        return exists;
    }


 public String random(){


     List<Words> words = getAllWords();      


    for (Words wrd : words) {

        String log = "WORDPOOL: "+ wrd.getWord() +" ID: "+ wrd.getId();
        stringList.add(wrd.getWord());


              // Writing Contacts to log
      Log.d("Name: ", log);
     } 


     selectedWord = randomGenerator.nextInt(stringList.size());

     System.out.println("HEY"+stringList.remove(selectedWord)+" "+selectedWord);
     randomWord = stringList.remove(selectedWord);

        return randomWord;

}

logcat

07-20 16:49:04.171: E/AndroidRuntime(4081): FATAL EXCEPTION: main
07-20 16:49:04.171: E/AndroidRuntime(4081): java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=1, result=-1, data=Intent { (has extras) }} to activity {com.flip/com.flip.main.friend}: java.lang.NullPointerException
07-20 16:49:04.171: E/AndroidRuntime(4081):     at android.app.ActivityThread.deliverResults(ActivityThread.java:2536)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at android.app.ActivityThread.handleSendResult(ActivityThread.java:2578)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at android.app.ActivityThread.access$2000(ActivityThread.java:117)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:965)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at android.os.Handler.dispatchMessage(Handler.java:99)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at android.os.Looper.loop(Looper.java:130)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at android.app.ActivityThread.main(ActivityThread.java:3687)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at java.lang.reflect.Method.invokeNative(Native Method)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at java.lang.reflect.Method.invoke(Method.java:507)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at dalvik.system.NativeStart.main(Native Method)
07-20 16:49:04.171: E/AndroidRuntime(4081): Caused by: java.lang.NullPointerException
07-20 16:49:04.171: E/AndroidRuntime(4081):     at com.flip.dao.DBHelper.exists(DBHelper.java:107)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at com.flip.main.friend.onActivityResult(friend.java:289)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at android.app.Activity.dispatchActivityResult(Activity.java:3908)
07-20 16:49:04.171: E/AndroidRuntime(4081):     at android.app.ActivityThread.deliverResults(ActivityThread.java:2532)
07-20 16:49:04.171: E/AndroidRuntime(4081):     ... 11 more

实现

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);

    switch (requestCode) {
    case RESULT_SPEECH: {
        if (resultCode == RESULT_OK && null != data) {

            ArrayList<String> text = data
                    .getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);

            txtText.setText(text.get(0));
            System.out.println(""+text.get(0));
            String wanted = text.get(0);



            if(dbHelp.exists(wanted)){

                gameScore = text.get(0).length()*10;

                TextView score = (TextView) findViewById(R.id.scoreView);

                score.setText(""+gameScore);


                playSound(R.raw.correct);
           }
    }
    }
}

最佳答案

这是我的问题伙计们..数据库仍然没有打开..为此,我打电话

db = this.getReadableDatabase

在 exists 方法中...

感谢回复...问候

关于java - 表名=空; NullPointerException 传送结果失败 ResultInfo{who=null, request=1, result=-1, data=Intent,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17760481/

相关文章:

android - 如何存储 Android 对话框中的编辑文本数据?

java - 如何在 SQLite 数据库中验证和添加新用户?

android - ORMLite 查询日期

java - 以多对多关系插入连接表

java - 如何检查字符串是否不等于对象?

Java:在数组中搜索整数值时出现 ArrayIndexOutOfBoundException

c# - SQLite 日期和时间数据类型

java - 在 Java 中,如何检查输入是否为数字?

c# - Kindle Fire 视频流式传输崩溃

android - 无法在 recyclerview 中获取行的圆角