неверный оператор в fillwindow () в Android - PullRequest
4 голосов
/ 23 ноября 2010

Я новичок в 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

1 Ответ

0 голосов
/ 09 декабря 2010
private DatabaseHelper myDbHelper; 
...
public void onStart() {
     DatabaseHelper myDbHelper = new DatabaseHelper(this);

Я удалил объявление DatabaseHelper в onStart.Это исправило ОШИБКУ / Курсор (1512)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...