检测到未闭合的光标

时间:2012-04-04 15:31:13

标签: android mapactivity

即使以最基本的形式启动MapActivity,我也会“检测到未关闭的光标”:

protected void onCreate(Bundle icicle) {
    super.onCreate(icicle); // <--- The Exception occurs here
    setContentView(R.layout.layout_map);
}

在例外之后,地图启动并完美运行,但每次启动活动时该异常都让我感到困扰。

例外:

  

04-04 12:02:22.858:W / Cursor(14122):检测到未闭合的光标   04-04 12:02:22.866:W / Cursor(14122):在android.content.ContentResolver.query(ContentResolver.java:258)   04-04 12:02:22.866:W / Cursor(14122):at com.google.common.android.AndroidConfig.getSetting(Unknown Source)   04-04 12:02:22.866:W / Cursor(14122):at com.google.common.android.AndroidConfig.getDistributionChannelInternal(Unknown Source)   04-04 12:02:22.866:W / Cursor(14122):at com.google.common.Config.init(Unknown Source)   04-04 12:02:22.866:W / Cursor(14122):at com.google.common.android.AndroidConfig。(Unknown Source)   04-04 12:02:22.866:W / Cursor(14122):at com.google.common.android.AndroidConfig。(Unknown Source)   04-04 12:02:22.866:W / Cursor(14122):at com.google.android.maps.MapActivity.onCreate(MapActivity.java:405)   04-04 12:02:22.866:W / Cursor(14122):at com.myapp.activity.MyMapActivity.onCreate(MyMapActivity.java:25)   04-04 12:02:22.874:W / Cursor(14122):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)   04-04 12:02:22.874:W / Cursor(14122):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2717)   04-04 12:02:22.874:W / Cursor(14122):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2769)   04-04 12:02:22.874:W / Cursor(14122):在android.app.ActivityThread.access $ 2500(ActivityThread.java:129)   04-04 12:02:22.874:W / Cursor(14122):在android.app.ActivityThread $ H.handleMessage(ActivityThread.java:2117)   04-04 12:02:22.874:W / Cursor(14122):在android.os.Handler.dispatchMessage(Handler.java:99)   04-04 12:02:22.874:W / Cursor(14122):在android.os.Looper.loop(Looper.java:143)   04-04 12:02:22.874:W / Cursor(14122):在android.app.ActivityThread.main(ActivityThread.java:4717)   04-04 12:02:22.874:W / Cursor(14122):at java.lang.reflect.Method.invokeNative(Native Method)   04-04 12:02:22.882:W / Cursor(14122):at java.lang.reflect.Method.invoke(Method.java:521)   04-04 12:02:22.882:W / Cursor(14122):at com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:858)   04-04 12:02:22.882:W / Cursor(14122):at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)   04-04 12:02:22.882:W / Cursor(14122):at dalvik.system.NativeStart.main(Native Method)

我在网上搜索但没有发现...... 额外信息:

  • 我正在使用Google API 2.2
  • 在设备上和AVD上测试
  • 让其他地图项目使用Google API 2.1(当然没有例外)
  • 我的AndroidManifest没有遗漏任何内容(因此地图会在抛出异常后启动并运行)

非常感谢帮助!

编辑:

我更新了Google API等级7和8(问题从8开始),现在它也发生在API等级7上......

绣球花让我注意到我的MapActivity(冰柱)中的Bundle变量名称与“标准”( savedInstanceState )不同,可能与问题有关?

2 个答案:

答案 0 :(得分:0)

您需要在获得数据库中的信息后关闭光标。

示例:

cursor.close();

你确定其他班级不存在问题吗?你的代码对我来说没问题。

答案 1 :(得分:0)

我在2.2设备上运行了这个,并没有得到任何这样的错误。您的活动中是否会发生其他可能导致此问题的事情?也许捆绑中的某些东西会导致super.onCreate()出现问题?

public class HelloGoogleMapsActivity extends MapActivity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
    }

    @Override
    protected boolean isRouteDisplayed() {
        // TODO Auto-generated method stub
        return false;
    }
}