【问题标题】:NullPointerException in loader: onLoadFinished() cursor is null Android加载程序中的 NullPointerException:onLoadFinished() 光标为空 Android
【发布时间】:2014-11-06 22:22:09
【问题描述】:

我正在构建一个应用程序,该应用程序通过自定义 contentprovider 使用 cursorloader 获取数据。数据是通过我也在构建的另一个应用程序插入的。但是我在必须获取数据的应用程序中得到了 NullPointerException。异常发生在 onLoadFinished() 方法中,光标返回 null。这真的很奇怪,因为我遵循了一个教程并且我已经完成了完全相同的步骤。如果我使用教程的 URI,它会检索插入的数据,并且光标不会返回 null。但如果我使用自己的 URI,则光标返回 null。有人可以帮帮我吗?

这是应用程序检索数据MainActivity.class的代码:

import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.LoaderManager;
import android.support.v4.content.CursorLoader;
import android.support.v4.content.Loader;
import android.view.Menu;
import android.view.View;
import android.widget.TextView;

public class MainActivity extends FragmentActivity implements LoaderManager.LoaderCallbacks<Cursor> {
    TextView resultView=null;       
    CursorLoader cursorLoader;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        resultView= (TextView) findViewById(R.id.res);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }

    public void onClickDisplayNames(View view) {
        getSupportLoaderManager().initLoader(1, null, this);
    }

    @Override
    public Loader<Cursor> onCreateLoader(int arg0, Bundle arg1) {
        String[] column = {"name"};
        cursorLoader= new CursorLoader(this, Uri.parse("content://com.ah.wholesalers.MyProvider/brand"),column, null, null, null);
        return cursorLoader;
    }

    @Override
    public void onLoadFinished(Loader<Cursor> arg0, Cursor cursor) {
        cursor.moveToFirst();
        StringBuilder res=new StringBuilder();
        while (!cursor.isAfterLast()) {
            res.append("\n"+ cursor.getString(1));
            cursor.moveToNext();
        }
        resultView.setText(res);
    }

    @Override
    public void onLoaderReset(Loader<Cursor> arg0) {
        // TODO Auto-generated method stub
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
    }

}

布局activity_main.xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >
    <Button
        android:id="@+id/btnRetrieve"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:onClick="onClickDisplayNames"
        android:text="Display names" />
    <TextView
        android:id="@+id/res"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="20dp"
        android:clickable="false"
        android:ems="10" >
    </TextView>
</LinearLayout>

这是我的 logcat,除了所有的例外:

11-05 17:23:13.672: E/AndroidRuntime(2044): FATAL EXCEPTION: main
11-05 17:23:13.672: E/AndroidRuntime(2044): Process: com.example.contentprovideruser, PID: 2044
11-05 17:23:13.672: E/AndroidRuntime(2044): java.lang.NullPointerException
11-05 17:23:13.672: E/AndroidRuntime(2044): at com.example.contentprovideruser.MainActivity.onLoadFinished(MainActivity.java:46)
11-05 17:23:13.672: E/AndroidRuntime(2044): at com.example.contentprovideruser.MainActivity.onLoadFinished(MainActivity.java:1)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.support.v4.app.LoaderManagerImpl$LoaderInfo.callOnLoadFinished(LoaderManager.java:427)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.support.v4.app.LoaderManagerImpl$LoaderInfo.onLoadComplete(LoaderManager.java:395)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.support.v4.content.Loader.deliverResult(Loader.java:103)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.support.v4.content.CursorLoader.deliverResult(CursorLoader.java:81)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.support.v4.content.CursorLoader.deliverResult(CursorLoader.java:35)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.support.v4.content.AsyncTaskLoader.dispatchOnLoadComplete(AsyncTaskLoader.java:221)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.support.v4.content.AsyncTaskLoader$LoadTask.onPostExecute(AsyncTaskLoader.java:61)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.support.v4.content.ModernAsyncTask.finish(ModernAsyncTask.java:461)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.support.v4.content.ModernAsyncTask.access$500(ModernAsyncTask.java:47)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.support.v4.content.ModernAsyncTask$InternalHandler.handleMessage(ModernAsyncTask.java:474)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.os.Handler.dispatchMessage(Handler.java:102)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.os.Looper.loop(Looper.java:136)
11-05 17:23:13.672: E/AndroidRuntime(2044): at android.app.ActivityThread.main(ActivityThread.java:5017)
11-05 17:23:13.672: E/AndroidRuntime(2044): at java.lang.reflect.Method.invokeNative(Native Method)
11-05 17:23:13.672: E/AndroidRuntime(2044): at java.lang.reflect.Method.invoke(Method.java:515)
11-05 17:23:13.672: E/AndroidRuntime(2044): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
11-05 17:23:13.672: E/AndroidRuntime(2044): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
11-05 17:23:13.672: E/AndroidRuntime(2044): at dalvik.system.NativeStart.main(Native Method)

【问题讨论】:

  • 我也有同样的问题,你解决了吗?我正在使用相同的教程。

标签: android android-contentprovider loader android-cursorloader android-loadermanager


【解决方案1】:

当我忘记在 AndroidManifest.xml 中声明提供程序时,我得到了空光标。

类似:

<provider android:name="com.ah.wholesalers.MyProvider"
  android:authorities="com.ah.wholesalers.MyProvider" 
  android:exported="false"/>

【讨论】:

    【解决方案2】:

    如果你使用的是Android Studio,你需要意识到manifest文件的属性包名

    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="no.glennbech.foodfacts">
    

    被 build.gradle 中的值覆盖

    defaultConfig {
          applicationId "no.yourdomain.yourapp"
          ...
    }
    

    该错误通常来自应用程序中的包名称(在 build.gradle 中定义)与提供程序“android:authorities”属性不匹配。

    <provider
        android:name="com.yoiurdomain.packagename.ClassOfProfivder"
        android:authorities="no.yourdomain.yourapp" /> 
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-04-05
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多