ошибка при получении количества строк в курсоре? - PullRequest
2 голосов
/ 27 февраля 2012

Я не знаю, почему приложение.вылетает при попытке отобразить количество выбранных строк внутри курсора.когда я комментирую строку, отображающую количество выбранных строк в приложении.работает нормально, иначе он вылетает.

Вот код:

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

    dbd = new DBDemoActivity(this);
    db = dbd.getWritableDatabase();
    cv = new ContentValues();

    cv.put("name", "Amr");
    cv.put("lat", 10);
    cv.put("lng", 20);
    newID = db.insert("Demo", null, cv);

    cv.put("name", "Mikila");
    cv.put("lat", 14);
    cv.put("lng", 22);
    newID = db.insert("Demo", null, cv);

    cv.put("name", "bakri");
    cv.put("lat", 17);
    cv.put("lng", 29);
    newID = db.insert("Demo", null, cv);

    cv.put("name", "geomatics");
    cv.put("lat", 50);
    cv.put("lng", 90);
    newID = db.insert("Demo", null, cv);
    }        

    SQLiteCursor c = (SQLiteCursor) db.rawQuery("SELECT * FROM Demo WHERE lat = 10", null);
    //c.moveToFirst();
    //Toast.makeText(getBaseContext(), c.getCount(), Toast.LENGTH_SHORT).show();
    //dbd.deleteMP(1);   
}   

}

LogCat:

02-27 10:46:35.675: E/AndroidRuntime(25525): FATAL EXCEPTION: main
02-27 10:46:35.675: E/AndroidRuntime(25525): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.androidbook.DBDemo/com.androidbook.DBDemo.DemoData}: android.content.res.Resources$NotFoundException: String resource ID #0x9
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1651)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.ActivityThread.access$1500(ActivityThread.java:117)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.os.Handler.dispatchMessage(Handler.java:99)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.os.Looper.loop(Looper.java:123)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.ActivityThread.main(ActivityThread.java:3691)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at java.lang.reflect.Method.invokeNative(Native Method)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at java.lang.reflect.Method.invoke(Method.java:507)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:847)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at dalvik.system.NativeStart.main(Native Method)
02-27 10:46:35.675: E/AndroidRuntime(25525): Caused by: android.content.res.Resources$NotFoundException: String resource ID #0x9
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.content.res.Resources.getText(Resources.java:222)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.widget.Toast.makeText(Toast.java:258)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at com.androidbook.DBDemo.DemoData.onCreate(DemoData.java:54)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
02-27 10:46:35.675: E/AndroidRuntime(25525):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1615)
02-27 10:46:35.675: E/AndroidRuntime(25525):    ... 11 more

Ответы [ 2 ]

1 голос
/ 27 февраля 2012

Проблема с Toast.makeText. makeText() - перегруженный метод, который доступен в двух вариантах -

makeText(Context c, String s, int duration)

и

makeText(Context, int resId, int duration)

То, что вы используете, является вторым (с resId) - так как cursor.getCount возвращает целое число. Теперь android пытается найти (в вашей папке Resources @gen), какой String является значением cursor.getCount, с которым он связан. Поскольку он не может его найти, он генерирует исключение $ NotFoundException для ресурсов.

исправлено: вместо cursor.getCount() попробуйте (String.valueOf (cursor.getCount ()))

0 голосов
/ 27 февраля 2012

Как происходит сбой?Вы должны выяснить детали вашей ошибки.Как вы можете понять проблемы, которые вы не совсем понимаете?

Посмотрите подробности своего logcat и найдите виновника и тип ошибки.

Возможны следующие варианты:

  • Ваш запрос занимает слишком много времени.Не очень хорошая идея иметь запрос БД в методе onCreate.Этот метод выполняется в потоке пользовательского интерфейса, и после 5 секунд бездействия ваше приложение завершится с ANR.Вы бы лучше обслуживались с помощью асинхронной задачи.
  • getBaseContext () кажется забавным, используйте это.

------- ОБНОВЛЕНИЕ -----

Ваша проблема в том, что вы передаете int тосту.Затем он ожидает, что int будет представлять идентификатор ресурса.

Если бы вы передали строку, у вас не было бы этой проблемы.Используйте

 Toast.makeText(getBaseContext(), String.valueOf( c.getCount() ), toast.LENGTH_SHORT).show();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...