jjzjj

android - 无法从具有0行,64列的CursorWindow读取第0行第0列

coder 2023-12-26 原文

我有时会在日志中发现这个错误。
无法从包含0行64列的游标窗口中读取行0、列0。
首先,讲点背景故事。我有一个应用程序在我们公司的许多设备上运行。目前,它主要运行在大约20个三星Note8设备、2个三星Note10.1设备和一些其他设备上。到目前为止,这个问题只发生在Note8中的两个设备上。在所有其他设备上,它似乎工作得很好。
该应用程序的工作原理是用户使用该应用程序收集信息、文本、照片、签名等…所有这些都作为提交表中的一行存储/插入到sqlite数据库中。submissions表有64列以满足收集的每个字段。有一个同步方法总是在运行(它是一个在可运行线程内执行的异步任务,因此即使应用程序关闭了,它仍然在后台同步数据,除非您从android任务管理器中滑动关闭它),它将数据同步到远程服务器,并检查如果需要同步,例如插入了新提交,则每10秒将开始同步该提交。当提交完成与服务器的同步并收到成功响应时,它将从设备的数据库中删除。到目前为止,它一直工作得很好,成千上万的提交已经成功同步等。然而,时不时地,我从一个或两个特定的注8平板电脑,重现这个问题的一个错误。我尝试了很多次来重新创建错误,但是当我测试它时它总是有效的,并且我尝试了所有类型的场景来测试它。
我的代码有数千行,所以我会尽量保持它的相关性。首先,这里是runnable的相关代码:

public Runnable myRunnable = new Runnable()
 {

    @Override
    public void run()
    { 
       count ++;
                if(count >= 10)
                {
                    android.util.Log.w("     SYNC     ", "---------------");
                    android.util.Log.w("     SYNC     ", "Checking if sync method is busy");
                    if(!syncBusy)
                    {
                        android.util.Log.w("     SYNC     ", "Sync method OPEN");
                        doSync();//This will start doing sync.
                        count = 0;
                    }
                    else
                    {
                    android.util.Log.w("     SYNC     ", "Sync method BUSY, will try again in 10 seconds");
                    android.util.Log.w("     SYNC     ", "---------------");
                    }
                }
                if(count == 1 && !syncBusy)
                {
                    checkSubmissionsLefttoSync();
                }
       mHandler.postDelayed(myRunnable, 1000);
    }
};

然后,dosync()方法是我进行上传的地方,也是我得到错误的地方。它有上千行长,所以我不想在这里发布代码。我可以说,除了产生上述错误的一个或两个异常之外,它对所有设备都100%工作。
另外,我将发布在sync方法中实际遍历数据库的部分:
        databaseHelper = new Handler_Database(this);
        Cursor cursor2 = databaseHelper.getAllUnsyncedSubmissions();

        if(cursor2.getCount() > 0) 
        {
            if(cursor2.moveToFirst())
            {

              do
                {
                    try
                    {
                       //doing lookups here and populating sync arrays
                    }
                    catch (IllegalStateException e)
                    {
                        //Do Nothing
                    }
                    catch (NullPointerException e)
                    {
                        //Do Nothing
                    }
                }
                while(cursor2.moveToNext());

            }
            else
            {

            }
        }
        else
        {

        }
         cursor2.close();
         databaseHelper.close();

我注意到了一些其他的事情,我不确定这是否是一个问题,但是,当我运行这个应用程序时,logcat输出以下行大约6或7次:
12:48:11.115 7416 7416调试sqliteopenhelper数据库版本:60
当应用程序启动时,我有自己的警告消息,这些消息只显示一次。但是,数据库版本和其他信息被多次写入logcat。这是个问题吗?这是否意味着我的数据库有某种bug,它会创建多个实例?
所有应用程序都会使用PlayStore中的签名APK进行更新。我的数据库onupgrade方法如下:
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
{
    // Drop older table if existed
    db.execSQL("DROP TABLE IF EXISTS " + TABLE_SUBMISSIONS);

    // Create tables again
    onCreate(db);
}

这对所有其他平板电脑和设备都适用。它们都会从PlayStore自动更新,并继续正常工作。但是,为什么logcat要多次输出这些行呢?
这可能是问题的一部分,为什么我得到的错误,正如在这篇文章的开头提到的?
任何可能的见解都将非常感谢。我已经拔头发好几个星期了,在我的代码中找不到任何错误。
更新1:
我刚看到这个警告:
08:30:58.710 16745 16745警告光标窗口已满:请求分配307333字节,可用空间249426字节,窗口大小2097152字节
我想这可能是我问题的根源。对如何有效解决这个问题有什么想法吗?
更新2:
我认为一个解决方案可能是限制使用光标从中检索的列。例如,所有小文本值/列。然后,为我知道占用了太多空间的每一列创建一个新查询。你认为这是个解决办法吗?有人吗?
更新3:
这可能行得通,我想在循环使用初始游标之后,我会在单独的游标中处理大字段。类似这样的东西(我刚刚写了一些psuedo代码):
Cursor c = db.rawQuery("SELECT Column1, Column2 .... FROM table " + ... , ...);

解决方案:
看看我的解决方案!https://stackoverflow.com/a/26797130/1518916

最佳答案

我完成了我的解决方案,现在效果很好。基本上,底线是在android上的sqlite数据库中存储大数据是不理想的。使用图像时,只需存储uri并将图像保存在设备上。但是,如果必须这样做,我建议不要将所有图像数据加载到同一个光标中,将它们拆分并执行多个查询。
请看我的答案https://stackoverflow.com/a/26797130/1518916

关于android - 无法从具有0行,64列的CursorWindow读取第0行第0列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26755590/

有关android - 无法从具有0行,64列的CursorWindow读取第0行第0列的更多相关文章

  1. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  2. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  3. ruby - 在 64 位 Snow Leopard 上使用 rvm、postgres 9.0、ruby 1.9.2-p136 安装 pg gem 时出现问题 - 2

    我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po

  4. ruby - 如何将脚本文件的末尾读取为数据文件(Perl 或任何其他语言) - 2

    我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚

  5. ruby - 什么是填充的 Base64 编码字符串以及如何在 ruby​​ 中生成它们? - 2

    我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%

  6. ruby-on-rails - 无法使用 Rails 3.2 创建插件? - 2

    我对最新版本的Rails有疑问。我创建了一个新应用程序(railsnewMyProject),但我没有脚本/生成,只有脚本/rails,当我输入ruby./script/railsgeneratepluginmy_plugin"Couldnotfindgeneratorplugin.".你知道如何生成插件模板吗?没有这个命令可以创建插件吗?PS:我正在使用Rails3.2.1和ruby​​1.8.7[universal-darwin11.0] 最佳答案 随着Rails3.2.0的发布,插件生成器已经被移除。查看变更日志here.现在

  7. ruby - 无法运行 Rails 2.x 应用程序 - 2

    我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby​​:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r

  8. ruby-on-rails - 无法在centos上安装therubyracer(V8和GCC出错) - 2

    我正在尝试在我的centos服务器上安装therubyracer,但遇到了麻烦。$geminstalltherubyracerBuildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingtherubyracer:ERROR:Failedtobuildgemnativeextension./usr/local/rvm/rubies/ruby-1.9.3-p125/bin/rubyextconf.rbcheckingformain()in-lpthread...yescheckingforv8.h...no***e

  9. Ruby 写入和读取对象到文件 - 2

    好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信

  10. ruby - 无法让 RSpec 工作—— 'require' : cannot load such file - 2

    我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳

随机推荐