草庐IT

android - ANR 错误 - 屏幕关闭 - 我应该如何处理它们?

coder 2023-12-05 原文

我在开发人员控制台上收到这条消息,指出我的应用程序已卡住,因为:

Intent 的 ANR 广播 { act=android.intent.action.SCREEN_OFF flg=0x40000000 }

没有堆栈跟踪,因为这是由 Froyo 之前的用户提出的。它甚至没有告诉我应用程序中的哪个 Activity 导致了错误 - 尽管我猜这是我的游戏 Activity 。

这也符合我自己的经验,有时当我的手机电池电量不足时,我的应用程序会卡住并且必须被终止。

我应该在我的 Activity 中做些什么来处理这种卡住状态吗?

我现在已经从市场上获得了一些适当的输出,但我仍然不知道如何处理它。

DALVIK THREADS:
"main" prio=5 tid=1 NATIVE
  | group="main" sCount=1 dsCount=0 obj=0x400227b0 self=0xce98
  | sysTid=4060 nice=0 sched=0/0 cgrp=default handle=-1345013476
  | schedstat=( 72099976000 6131816000 28732 )
  at android.media.SoundPool.play(Native Method)
  at com.bazsoft.yaniv.SoundManager.playSound(SoundManager.java:88)
  at com.bazsoft.yaniv.YanivGameActivity.displayPileCards(YanivGameActivity.java:675)
  at com.bazsoft.yaniv.YanivGameActivity.access$22(YanivGameActivity.java:659)
  at com.bazsoft.yaniv.YanivGameActivity$1.run(YanivGameActivity.java:628)
  at android.app.Activity.runOnUiThread(Activity.java:3713)
  at com.bazsoft.yaniv.YanivGameActivity.displayCards(YanivGameActivity.java:615)
  at com.bazsoft.yaniv.YanivGameActivity.access$6(YanivGameActivity.java:614)
  at com.bazsoft.yaniv.YanivGameActivity$ComputerHandler.handleMessage(YanivGameActivity.java:121)
  at android.os.Handler.dispatchMessage(Handler.java:99)
  at android.os.Looper.loop(Looper.java:143)
  at android.app.ActivityThread.main(ActivityThread.java:4701)
  at java.lang.reflect.Method.invokeNative(Native Method)
  at java.lang.reflect.Method.invoke(Method.java:521)
  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:859)
  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:617)
  at dalvik.system.NativeStart.main(Native Method)

"AsyncTask #5" prio=5 tid=19 WAIT
  | group="main" sCount=1 dsCount=0 obj=0x464cbd98 self=0x47f208
  | sysTid=4877 nice=10 sched=0/0 cgrp=default handle=4216856
  | schedstat=( 13501000 72691000 93 )
  at java.lang.Object.wait(Native Method)
  - waiting on <0x4648bbd0> (a java.lang.VMThread)
  at java.lang.Thread.parkFor(Thread.java:1535)
  at java.lang.LangAccessImpl.parkFor(LangAccessImpl.java:48)
  at sun.misc.Unsafe.park(Unsafe.java:317)
  at java.util.concurrent.locks.LockSupport.park(LockSupport.java:131)
  at  java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:1996)
  at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:359)
  at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1001)
  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1061)
  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
  at java.lang.Thread.run(Thread.java:1096)

"AsyncTask #4" prio=5 tid=22 WAIT
  | group="main" sCount=1 dsCount=0 obj=0x465379d8 self=0x460698
  | sysTid=4796 nice=10 sched=0/0 cgrp=default handle=4864896
  | schedstat=( 14816000 60081000 94 )
  at java.lang.Object.wait(Native Method)
  - waiting on <0x46491a40> (a java.lang.VMThread)
  at java.lang.Thread.parkFor(Thread.java:1535)
  at java.lang.LangAccessImpl.parkFor(LangAccessImpl.java:48)
  at sun.misc.Unsafe.park(Unsafe.java:317)
  at java.util.concurrent.locks.LockSupport.park(LockSupport.java:131)
  at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:1996)
  at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:359)
  at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1001)
  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1061)
  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
  at java.lang.Thread.run(Thread.java:1096)

"AsyncTask #3" prio=5 tid=21 WAIT
  | group="main" sCount=1 dsCount=0 obj=0x46558de8 self=0x44f1a8
  | sysTid=4759 nice=10 sched=0/0 cgrp=default handle=4865256
  | schedstat=( 17781000 122763000 125 )
  at java.lang.Object.wait(Native Method)
  - waiting on <0x46545340> (a java.lang.VMThread)
  at java.lang.Thread.parkFor(Thread.java:1535)
  at java.lang.LangAccessImpl.parkFor(LangAccessImpl.java:48)
  at sun.misc.Unsafe.park(Unsafe.java:317)
  at java.util.concurrent.locks.LockSupport.park(LockSupport.java:131)
  at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:1996)
  at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:359)
  at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1001)
  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1061)
  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
  at java.lang.Thread.run(Thread.java:1096)

"Binder Thread #3" prio=5 tid=20 NATIVE
  | group="main" sCount=1 dsCount=0 obj=0x463e9610 self=0x4958e8
  | sysTid=4750 nice=0 sched=0/0 cgrp=default handle=4807336
  | schedstat=( 8851000 15266000 40 )
  at dalvik.system.NativeStart.run(Native Method)

"AsyncTask #2" prio=5 tid=18 WAIT
  | group="main" sCount=1 dsCount=0 obj=0x464423c8 self=0x48dad8
  | sysTid=4737 nice=10 sched=0/0 cgrp=default handle=3804272
  | schedstat=( 14045000 80530000 96 )
  at java.lang.Object.wait(Native Method)
  - waiting on <0x464c2db8> (a java.lang.VMThread)
  at java.lang.Thread.parkFor(Thread.java:1535)
  at java.lang.LangAccessImpl.parkFor(LangAccessImpl.java:48)
  at sun.misc.Unsafe.park(Unsafe.java:317)
  at java.util.concurrent.locks.LockSupport.park(LockSupport.java:131)
  at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:1996)
  at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:359)
  at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1001)
  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1061)
  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
  at java.lang.Thread.run(Thread.java:1096)

"AsyncTask #1" prio=5 tid=8 WAIT
  | group="main" sCount=1 dsCount=0 obj=0x464dfed8 self=0x41b5e8
  | sysTid=4550 nice=10 sched=0/0 cgrp=default handle=3585048
  | schedstat=( 12129000 58868000 77 )
  at java.lang.Object.wait(Native Method)
  - waiting on <0x464eefa0> (a java.lang.VMThread)
  at java.lang.Thread.parkFor(Thread.java:1535)
  at java.lang.LangAccessImpl.parkFor(LangAccessImpl.java:48)
  at sun.misc.Unsafe.park(Unsafe.java:317)
  at java.util.concurrent.locks.LockSupport.park(LockSupport.java:131)
  at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:1996)
  at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:359)
  at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1001)
  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1061)
  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
  at java.lang.Thread.run(Thread.java:1096)

"WebViewWorkerThread" prio=5 tid=17 WAIT
  | group="main" sCount=1 dsCount=0 obj=0x4644d988 self=0x32d200
  | sysTid=4099 nice=1 sched=0/0 cgrp=default handle=3330880
  | schedstat=( 74615000 42294000 225 )
  at java.lang.Object.wait(Native Method)
  - waiting on <0x4644dbc8> (a android.os.MessageQueue)
  at java.lang.Object.wait(Object.java:288)
  at android.os.MessageQueue.next(MessageQueue.java:146)
  at android.os.Looper.loop(Looper.java:123)
  at android.os.HandlerThread.run(HandlerThread.java:60)

"http3" prio=5 tid=16 WAIT
  | group="main" sCount=1 dsCount=0 obj=0x46438aa8 self=0x32c618
  | sysTid=4098 nice=1 sched=0/0 cgrp=default handle=3327832
  | schedstat=( 9630000 2435000 22 )
  at java.lang.Object.wait(Native Method)
  - waiting on <0x46437ce8> (a android.net.http.RequestQueue)
  at java.lang.Object.wait(Object.java:288)
  at android.net.http.ConnectionThread.run(ConnectionThread.java:98)

"http2" prio=5 tid=15 WAIT
  | group="main" sCount=1 dsCount=0 obj=0x464388b8 self=0x32bbd0
  | sysTid=4097 nice=1 sched=0/0 cgrp=default handle=3325200
  | schedstat=( 6453000 547000 21 )
  at java.lang.Object.wait(Native Method)
  - waiting on <0x46437ce8> (a android.net.http.RequestQueue)
  at java.lang.Object.wait(Object.java:288)
  at android.net.http.ConnectionThread.run(ConnectionThread.java:98)

"http1" prio=5 tid=14 WAIT
  | group="main" sCount=1 dsCount=0 obj=0x464386c8 self=0x32afb0
  | sysTid=4095 nice=1 sched=0/0 cgrp=default handle=3322096
  | schedstat=( 14060000 4044000 35 )
  at java.lang.Object.wait(Native Method)
  - waiting on <0x46437ce8> (a android.net.http.RequestQueue)
  at java.lang.Object.wait(Object.java:288)
  at android.net.http.ConnectionThread.run(ConnectionThread.java:98)

"http0" prio=5 tid=11 WAIT
  | group="main" sCount=1 dsCount=0 obj=0x464384d8 self=0x31b898
  | sysTid=4094 nice=1 sched=0/0 cgrp=default handle=3263064
  | schedstat=( 10561000 11218000 28 )
  at java.lang.Object.wait(Native Method)
  - waiting on <0x46437ce8> (a android.net.http.RequestQueue)
  at java.lang.Object.wait(Object.java:288)
  at android.net.http.ConnectionThread.run(ConnectionThread.java:98)

"SoundPool" prio=5 tid=13 NATIVE
  | group="main" sCount=1 dsCount=0 obj=0x464237e0 self=0x2e4a08
  | sysTid=4077 nice=0 sched=0/0 cgrp=default handle=2519808
  | schedstat=( 236000 6104000 5 )
  at dalvik.system.NativeStart.run(Native Method)

"SoundPoolThread" prio=5 tid=12 NATIVE
  | group="main" sCount=1 dsCount=0 obj=0x46418800 self=0x2def70
  | sysTid=4078 nice=0 sched=0/0 cgrp=default handle=2520264
  | schedstat=( 4442000 4642000 55 )
  at dalvik.system.NativeStart.run(Native Method)

"pool-1-thread-1" prio=5 tid=10 WAIT 
  | group="main" sCount=1 dsCount=0 obj=0x463f2218 self=0x2ca760
  | sysTid=4075 nice=0 sched=0/0 cgrp=default handle=2878472
  | schedstat=( 86256000 83712000 143 )
  at java.lang.Object.wait(Native Method)
  - waiting on <0x463f2488> (a java.lang.VMThread)
  at java.lang.Thread.parkFor(Thread.java:1535)
  at java.lang.LangAccessImpl.parkFor(LangAccessImpl.java:48)
  at sun.misc.Unsafe.park(Unsafe.java:317)
  at java.util.concurrent.locks.LockSupport.park(LockSupport.java:131)
  at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:1996)
  at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:359)
  at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1001)
  at java.uti...

最佳答案

Android 会在检测到以下情况之一时显示特定应用程序的 ANR 对话框: • 5 秒内没有对输入事件(例如按键、屏幕触摸)的响应。 • BroadcastReceiver 未在 10 秒内完成执行。

关于android - ANR 错误 - 屏幕关闭 - 我应该如何处理它们?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8082321/

有关android - ANR 错误 - 屏幕关闭 - 我应该如何处理它们?的更多相关文章

  1. 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

  2. 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%

  3. ruby - 检查 "command"的输出应该包含 NilClass 的意外崩溃 - 2

    为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar

  4. ruby-on-rails - Enumerator.new 如何处理已通过的 block ? - 2

    我在理解Enumerator.new方法的工作原理时遇到了一些困难。假设文档中的示例:fib=Enumerator.newdo|y|a=b=1loopdoy[1,1,2,3,5,8,13,21,34,55]循环中断条件在哪里,它如何知道循环应该迭代多少次(因为它没有任何明确的中断条件并且看起来像无限循环)? 最佳答案 Enumerator使用Fibers在内部。您的示例等效于:require'fiber'fiber=Fiber.newdoa=b=1loopdoFiber.yieldaa,b=b,a+bendend10.times.m

  5. 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

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

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

  7. 使用 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

  8. 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

  9. 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

  10. 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

随机推荐