草庐IT

android - Google Drive API await() UI 线程错误

coder 2023-12-12 原文

我正在我的 android 应用程序中实现 Google Drive API。我不想使用 PendingResult#setResultCallback(),而是想使用 PendingResult#await() 这样我就可以在下一行得到结果而不必等待。这不是问题,因为一切都在后台运行。

但是,每次调用 await() 时,都会出现以下错误。我已经尝试对在 AsyncTask、线程、IntentService、AsyncTask 服务和线程服务中使用 await() 的 Google Drive API 进行一次调用。我每次都收到以下错误。我尝试在我的 Thread 实现中调用 Looper.prepare(),但它没有解决任何问题。

还有其他人遇到过这个问题吗?

java.lang.IllegalStateException: await must not be called on the UI thread
        at com.google.android.gms.internal.hm.a(Unknown Source)
        at com.google.android.gms.common.api.a$a.await(Unknown Source)
        at [OMITTED].GoogleDriveManager$2.onConnected(GoogleDriveManager.java:83)
        at com.google.android.gms.internal.hc.c(Unknown Source)
        at com.google.android.gms.common.api.c.eK(Unknown Source)
        at com.google.android.gms.common.api.c.d(Unknown Source)
        at com.google.android.gms.common.api.c$2.onConnected(Unknown Source)
        at com.google.android.gms.internal.hc.c(Unknown Source)
        at com.google.android.gms.internal.hc.cp(Unknown Source)
        at com.google.android.gms.internal.hb$h.b(Unknown Source)
        at com.google.android.gms.internal.hb$h.d(Unknown Source)
        at com.google.android.gms.internal.hb$b.fv(Unknown Source)
        at com.google.android.gms.internal.hb$a.handleMessage(Unknown Source)
        at android.os.Handler.dispatchMessage(Handler.java:102)
        at android.os.Looper.loop(Looper.java:136)
        at android.app.ActivityThread.main(ActivityThread.java:5146)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:515)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:796)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:612)
        at dalvik.system.NativeStart.main(Native Method)

这是我用来测试 API 的代码:

     apiClient = new GoogleApiClient.Builder(mContext)
            .addApi(Drive.API)
            .addScope(Drive.SCOPE_APPFOLDER)
            .addConnectionCallbacks(new GoogleApiClient.ConnectionCallbacks() {
                @Override
                public void onConnected(Bundle bundle) {
                    LogUtil.log(TAG, "onConnected()");
                    connected = true;

                    DriveApi.ContentsResult result = Drive.DriveApi.newContents(apiClient).await();

                }
                @Override
                public void onConnectionSuspended(int i) {
                    LogUtil.log(TAG, "onConnectionSuspended()");
                    connected = false;
                }
            })
            .addOnConnectionFailedListener(new GoogleApiClient.OnConnectionFailedListener() {
                @Override
                public void onConnectionFailed(ConnectionResult result) {
                    LogUtil.log(TAG, "onConnectionFailed()");
                    connected = false;
                }
            })
            .build();
    apiClient.connect();

最佳答案

apiClient.connect()是一个异步操作,因此为什么在 AsyncTask 中调用它没有帮助(在 UI 线程上调用 onConnected() 时在后台线程上运行连接没有帮助)。

相反,您可以从 onConnected() 启动一个 AsyncTask回调 - AsyncTask 的 doInBackground()然后可以调用Drive.DriveApi.newContents(apiClient).await() .

当然,没有必要调用 await() - 使用 setResultCallback()异步等待 newContents()完成:

@Override
public void onConnected(Bundle bundle) {
  LogUtil.log(TAG, "onConnected()");
  connected = true;

  Drive.DriveApi.newContents(apiClient).setResultCallback(
       new ResultCallback<DriveApi.ContentsResult>() {
     @Override
     public void onResult(DriveApi.ContentsResult result) {
       // Use result
     }
  });
}

关于android - Google Drive API await() UI 线程错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26303159/

有关android - Google Drive API await() UI 线程错误的更多相关文章

  1. ruby - i18n Assets 管理/翻译 UI - 2

    我正在使用i18n从头开始​​构建一个多语言网络应用程序,虽然我自己可以处理一大堆yml文件,但我说的语言(非常)有限,最终我想寻求外部帮助帮助。我想知道这里是否有人在使用UI插件/gem(与django上的django-rosetta不同)来处理多个翻译器,其中一些翻译器不愿意或无法处理存储库中的100多个文件,处理语言数据。谢谢&问候,安德拉斯(如果您已经在ruby​​onrails-talk上遇到了这个问题,我们深表歉意) 最佳答案 有一个rails3branchofthetolkgem在github上。您可以通过在Gemfi

  2. ruby-on-rails - Rails 常用字符串(用于通知和错误信息等) - 2

    大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje

  3. ruby-on-rails - 迷你测试错误 : "NameError: uninitialized constant" - 2

    我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test

  4. ruby - RuntimeError(自动加载常量 Apps 多线程时检测到循环依赖 - 2

    我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("

  5. ruby-on-rails - 如何在 Rails View 上显示错误消息? - 2

    我是rails的新手,想在form字段上应用验证。myviewsnew.html.erb.....模拟.rbclassSimulation{:in=>1..25,:message=>'Therowmustbebetween1and25'}end模拟Controller.rbclassSimulationsController我想检查模型类中row字段的整数范围,如果不在范围内则返回错误信息。我可以检查上面代码的范围,但无法返回错误消息提前致谢 最佳答案 关键是您使用的是模型表单,一种显示ActiveRecord模型实例属性的表单。c

  6. 使用 ACL 调用 upload_file 时出现 Ruby S3 "Access Denied"错误 - 2

    我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file

  7. ruby-on-rails - 错误 : Error installing pg: ERROR: Failed to build gem native extension - 2

    我克隆了一个rails仓库,我现在正尝试捆绑安装背景:OSXElCapitanruby2.2.3p173(2015-08-18修订版51636)[x86_64-darwin15]rails-v在您的Gemfile中列出的或native可用的任何gem源中找不到gem'pg(>=0)ruby​​'。运行bundleinstall以安装缺少的gem。bundleinstallFetchinggemmetadatafromhttps://rubygems.org/............Fetchingversionmetadatafromhttps://rubygems.org/...Fe

  8. ruby - #之间? Cooper 的 *Beginning Ruby* 中的错误或异常 - 2

    在Cooper的书BeginningRuby中,第166页有一个我无法重现的示例。classSongincludeComparableattr_accessor:lengthdef(other)@lengthother.lengthenddefinitialize(song_name,length)@song_name=song_name@length=lengthendenda=Song.new('Rockaroundtheclock',143)b=Song.new('BohemianRhapsody',544)c=Song.new('MinuteWaltz',60)a.betwee

  9. ruby-on-rails - 每次我尝试部署时,我都会得到 - (gcloud.preview.app.deploy) 错误响应 : [4] DEADLINE_EXCEEDED - 2

    我是Google云的新手,我正在尝试对其进行首次部署。我的第一个部署是RubyonRails项目。我基本上是在关注thisguideinthegoogleclouddocumentation.唯一的区别是我使用的是我自己的项目,而不是他们提供的“helloworld”项目。这是我的app.yaml文件runtime:customvm:trueentrypoint:bundleexecrackup-p8080-Eproductionconfig.ruresources:cpu:0.5memory_gb:1.3disk_size_gb:10当我转到我的项目目录并运行gcloudprevie

  10. ruby-on-rails - Rails 5 Active Record 记录无效错误 - 2

    我有两个Rails模型,即Invoice和Invoice_details。一个Invoice_details属于Invoice,一个Invoice有多个Invoice_details。我无法使用accepts_nested_attributes_forinInvoice通过Invoice模型保存Invoice_details。我收到以下错误:(0.2ms)BEGIN(0.2ms)ROLLBACKCompleted422UnprocessableEntityin25ms(ActiveRecord:4.0ms)ActiveRecord::RecordInvalid(Validationfa

随机推荐