Я новичок в Android и прежде чем задать вопрос, я гуглил, но на этот вопрос я не могу найти ответ. (также этот stackoverflow.com/questions/4195089 не имеет ответа).
В моем тестовом приложении на эмуляторе у меня ошибка ОШИБКА / Курсор (1512): неверный оператор в fillWindow () в LogCat, когда я нажимаю кнопку "Назад" во втором действии.
11-23 19: 06: 05.050: DEBUG / TestDB / Debug / MainActivity (1512): onCreate
11-23 19: 06: 06.820: DEBUG / TestDB / Debug / MainActivity (1512): openDataBase
11-23 19: 06: 07.240: DEBUG / TestDB / Debug / MainActivity (1512): строка [] из
11-23 19: 06: 07.270: DEBUG / TestDB / Debug / MainActivity (1512): SimpleCursorAdapter
11-23 19: 06: 07.500: DEBUG / TestDB / Debug / MainActivity (1512): myDbHelper.close
11-23 19: 06: 07.520: DEBUG / TestDB / Debug / MainActivity (1512): onStart
11-23 19: 06: 07.551: DEBUG / TestDB / Debug / MainActivity (1512): onResume
11-23 19: 06: 09.040: INFO / ActivityManager (587): отображаемое действие ru.olegi / .MainActivity: 7962 мс
11-23 19: 06: 11.850: INFO / ActivityManager (587): начало деятельности: намерение {comp = {ru.olegi / ru.olegi.AnotherActivity}}
11-23 19: 06: 12.100: DEBUG / TestDB / Debug / AnotherActivity (1512): onCreate
11-23 19: 06: 12.970: INFO / ActivityManager (587): отображаемое действие ru.olegi / .AnotherActivity: 1100 мс
11-23 19: 06: 14.550: ОШИБКА / Курсор (1512): неверный оператор в fillWindow ()
11-23 19: 06: 14.590: DEBUG / TestDB / Debug / MainActivity (1512): onStart
11-23 19: 06: 14.600: DEBUG / TestDB / Debug / MainActivity (1512): onResume
Весь код хранится в onCreate. Поэтому, когда я нажимаю назад, ListView пуст. Для исправления этого я переместить код на OnStart. Вот лог для этого и снова есть неверный оператор в fillWindow ()
11-23 19: 26: 06.280: DEBUG / TestDB / Debug / MainActivity (6597): onCreate
11-23 19: 26: 06.462: DEBUG / TestDB / Debug / MainActivity (6597): onStart
11-23 19: 26: 06.700: DEBUG / TestDB / Debug / MainActivity (6597): openDataBase
11-23 19: 26: 06.740: DEBUG / TestDB / Debug / MainActivity (6597): строка [] из
11-23 19: 26: 06.750: DEBUG / TestDB / Debug / MainActivity (6597): SimpleCursorAdapter
11-23 19: 26: 06.981: DEBUG / TestDB / Debug / MainActivity (6597): myDbHelper.close
11-23 19: 26: 07.010: DEBUG / TestDB / Debug / MainActivity (6597): onResume
11-23 19: 26: 08.030: INFO / ActivityManager (587): отображаемое действие ru.olegi / .MainActivity: 3876 мс
11-23 19: 26: 15.419: INFO / ActivityManager (587): начало деятельности: намерение {comp = {ru.olegi / ru.olegi.AnotherActivity}}
11-23 19: 26: 15.770: DEBUG / TestDB / Debug / AnotherActivity (6597): onCreate
11-23 19: 26: 16.440: INFO / ActivityManager (587): отображаемое действие ru.olegi / .AnotherActivity: 1001 мс
11-23 19: 26: 17.860: ОШИБКА / Курсор (6597): неверный оператор в fillWindow ()
11-23 19: 26: 17.870: DEBUG / TestDB / Debug / MainActivity (6597): onStart
11-23 19: 26: 18.260: DEBUG / TestDB / Debug / MainActivity (6597): openDataBase
11-23 19: 26: 18.290: DEBUG / TestDB / Debug / MainActivity (6597): строка [] из
11-23 19: 26: 18.310: DEBUG / TestDB / Debug / MainActivity (6597): SimpleCursorAdapter
11-23 19: 26: 18.670: DEBUG / TestDB / Debug / MainActivity (6597): myDbHelper.close
11-23 19: 26: 18.700: DEBUG / TestDB / Debug / MainActivity (6597): onResume
Этот код
package ru.olegi;
import java.io.IOException;
import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.database.SQLException;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
public class MainActivity extends Activity {
/** Called when the activity is first created. */
private DatabaseHelper myDbHelper;
private ListView lv1;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.d("TestDB/Debug/MainActivity", "onCreate");
setContentView(R.layout.main);
}
@Override
public void onStart() {
super.onStart();
Log.d("TestDB/Debug/MainActivity", "onStart");
// DATABASE OPEN - START
DatabaseHelper myDbHelper = new DatabaseHelper(this);
myDbHelper = new DatabaseHelper(this);
try {
myDbHelper.createDataBase();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
myDbHelper.openDataBase();
}catch(SQLException sqle){
throw sqle;
}
Log.d("TestDB/Debug/MainActivity", "openDataBase");
// DATABASE OPEN - END
Cursor c = myDbHelper.fetchAllFoodname();
startManagingCursor(c);
lv1 = (ListView) findViewById(R.id.ListView01);
String[] from = new String[] { DatabaseHelper.KEY_NAME };
int[] to = new int[] { android.R.id.text1};
Log.d("TestDB/Debug/MainActivity", "String[] from");
SimpleCursorAdapter notes =
new SimpleCursorAdapter(this, android.R.layout.simple_list_item_1, c, from, to);
Log.d("TestDB/Debug/MainActivity", "SimpleCursorAdapter");
lv1.setAdapter(notes);
lv1.setOnItemClickListener(new OnItemClickListener() {
//@Override
public void onItemClick(AdapterView<?> a, View v, int position, long id) {
Intent intent = new Intent();
//getApplicationContext()
intent.setClass(MainActivity.this, AnotherActivity.class);
//intent.putExtra(AnotherActivity.EXT_ID, id);
startActivity(intent);
//finish();
}
});
// DATABASE CLOSE - START
myDbHelper.close();
Log.d("TestDB/Debug/MainActivity", "myDbHelper.close");
// DATABASE CLOSE - END
}
@Override
public void onResume(){
super.onResume();
Log.d("TestDB/Debug/MainActivity", "onResume");
}
@Override
public void onDestroy(){
super.onDestroy();
Log.d("TestDB/Debug/MainActivity", "onDestroy");
}
}
Здесь groups.google.com/group/android-developers/browse_thread/thread/8bec793c626fb405, которую я прочитал, для устранения ошибки fillwindow () требуется
краткий ответ; Ваш объект базы данных
(дб) находится в неправильном объеме. дольше
ответ; Объявляя дБ в методе
вы говорите JVM, что когда
метод заканчивает вашу базу данных
соединение (дБ) больше не полезно.
Что вы должны сделать, это объявить БД в
уровень класса вместо метода
уровень, создать его в onCreate, и
закройте его в onDestroy.
Хорошо, я перемещаю разделы // БАЗА ДАННЫХ ОТКРЫТО - НАЧАТЬ и // ЗАКРЫТЬ БАЗУ ДАННЫХ - НАЧАТЬ, чтобы создать и создать.И теперь у меня есть исключение на старте 11-23 19: 35: 39.310: DEBUG / TestDB / Debug / MainActivity (8975): onCreate11-23 19: 35: 40.050: DEBUG / TestDB / Debug / MainActivity (8975): openDataBase11-23 19: 35: 40.050: DEBUG / TestDB / Debug / MainActivity (8975): onStart11-23 19: 35: 40.090: DEBUG / AndroidRuntime (8975): выключение виртуальной машины11-23 19: 35: 40.100: WARN / dalvikvm (8975): threadid = 3: поток завершается с необработанным исключением (группа = 0x4000fe70)11-23 19: 35: 40.120: ОШИБКА / AndroidRuntime (8975): обработчик Uncaught: выход из основного потока из-за необработанного исключения11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): java.lang.RuntimeException: Невозможно начать действие11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2268)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:2284)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на android.app.ActivityThread.access $ 1800 (ActivityThread.java:112)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на android.app.ActivityThread $ H.handleMessage (ActivityThread.java:1692)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на android.os.Handler.dispatchMessage (Handler.java:99)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на android.os.Looper.loop (Looper.java:123)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на android.app.ActivityThread.main (ActivityThread.java:3948)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на java.lang.reflect.Method.invokeNative (собственный метод)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): в java.lang.reflect.Method.invoke (Method.java:521)11-23 19: 35: 40.300: ERROR / AndroidRuntime (8975): на com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java:782)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на com.android.internal.os.ZygoteInit.main (ZygoteInit.java:540)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): в dalvik.system.NativeStart.main (собственный метод)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): вызвано: java.lang.NullPointerException11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на ru.olegi.MainActivity.onStart (MainActivity.java:59)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на android.app.Instrumentation.callActivityOnStart (Instrumentation.java:1205)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на android.app.Activity.performStart (Activity.java:3490)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): на android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2240)11-23 19: 35: 40.300: ОШИБКА / AndroidRuntime (8975): ... еще 11
Вот код с перемещенными db-разделами:
package ru.olegi;
import java.io.IOException;
import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.database.SQLException;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
public class MainActivity extends Activity {
/** Called when the activity is first created. */
private DatabaseHelper myDbHelper;
private ListView lv1;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.d("TestDB/Debug/MainActivity", "onCreate");
setContentView(R.layout.main);
// DATABASE OPEN - START
DatabaseHelper myDbHelper = new DatabaseHelper(this);
myDbHelper = new DatabaseHelper(this);
try {
myDbHelper.createDataBase();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
myDbHelper.openDataBase();
}catch(SQLException sqle){
throw sqle;
}
Log.d("TestDB/Debug/MainActivity", "openDataBase");
// DATABASE OPEN - END
}
@Override
public void onStart() {
super.onStart();
Log.d("TestDB/Debug/MainActivity", "onStart");
Cursor c = myDbHelper.fetchAllFoodname();
startManagingCursor(c);
lv1 = (ListView) findViewById(R.id.ListView01);
String[] from = new String[] { DatabaseHelper.KEY_NAME };
int[] to = new int[] { android.R.id.text1};
Log.d("TestDB/Debug/MainActivity", "String[] from");
SimpleCursorAdapter notes =
new SimpleCursorAdapter(this, android.R.layout.simple_list_item_1, c, from, to);
Log.d("TestDB/Debug/MainActivity", "SimpleCursorAdapter");
lv1.setAdapter(notes);
lv1.setOnItemClickListener(new OnItemClickListener() {
//@Override
public void onItemClick(AdapterView<?> a, View v, int position, long id) {
Intent intent = new Intent();
//getApplicationContext()
intent.setClass(MainActivity.this, AnotherActivity.class);
//intent.putExtra(AnotherActivity.EXT_ID, id);
startActivity(intent);
//finish();
}
});
}
@Override
public void onResume(){
super.onResume();
Log.d("TestDB/Debug/MainActivity", "onResume");
}
@Override
public void onDestroy(){
super.onDestroy();
Log.d("TestDB/Debug/MainActivity", "onDestroy");
// DATABASE CLOSE - START
myDbHelper.close();
Log.d("TestDB/Debug/MainActivity", "myDbHelper.close");
// DATABASE CLOSE - END
}
}
Пожалуйста, помогите исправить Неверный оператор в fillWindow ()
AnotherActivity - простос TextView у MainActivity есть только listview + onclick listener