我现在几乎完成了我的游戏,但今天我遇到了一个真正令人讨厌的问题.当我开始游戏并等待几分钟时,程序会自动关闭.而且我没有说明它.

这是我的logcat显示的内容:

01-22 16:20:31.232: DEBUG/szipinf(333): Initializing inflate state
01-22 16:20:31.563: DEBUG/PhoneWindow(333): Couldn't save which view has focus because the focused view com.JDLApps.Snake.FrameWork.AndroidFastRenderView@4050f950 has no id.
01-22 16:20:36.362: WARN/ActivityManager(73): Activity pause timeout for HistoryRecord{406532f8 com.JDL.Apps.Snake/.SnakeGame}
01-22 16:20:43.682: INFO/ActivityManager(73): Start proc com.android.launcher for activity com.android.launcher/com.android.launcher2.Launcher: pid=358 uid=10026 gids={}
01-22 16:21:20.393: ERROR/Inputdispatcher(73): channel '406762c0 com.JDL.Apps.Snake/com.JDL.Apps.Snake.SnakeGame (server)' ~ Consumer closed input channel or an error occurred.  events=0x8
01-22 16:21:20.402: ERROR/Inputdispatcher(73): channel '406762c0 com.JDL.Apps.Snake/com.JDL.Apps.Snake.SnakeGame (server)' ~ Channel is unrecoverably broken and will be disposed!
01-22 16:21:21.092: INFO/WindowManager(73): WIN DEATH: Window{406762c0 com.JDL.Apps.Snake/com.JDL.Apps.Snake.SnakeGame paused=false}
01-22 16:21:21.142: WARN/ActivityManager(73): Timeout of broadcast broadcastRecord{40728640 android.intent.action.TIME_TICK} - receiver=android.app.LoadedApk$Receiverdispatcher$InnerReceiver@406300f8,started 56630ms ago
01-22 16:21:21.142: WARN/ActivityManager(73): Receiver during timeout: broadcastFilter{4062f930 ReceiverList{4062f8b8 73 system/1000 local:406300f8}}
01-22 16:21:21.172: INFO/ActivityManager(73): Process com.JDL.Apps.Snake (pid 333) has died.
01-22 16:21:21.362: INFO/WindowManager(73): WIN DEATH: Window{4072b188 SurfaceView paused=false}
01-22 16:21:21.443: INFO/ActivityManager(73): Low Memory: No more background processes.

我遗憾的是没有代码可以分享,因为我不知道程序崩溃了.

编辑:绘图代码:

@Override
public void screen(float deltaTime) {
    Graphics g = app.getGraphics();

    g.drawpixmap(Assets.background,0);

    g.drawpixmap(Assets.facebook,750,20);

    g.drawText("SNAKE",10,150,Color.BLACK,AndroidGraphics.LEFT,null,0);
    g.drawText("START",g.getWidth() / 2,g.getHeight() - 20,120,AndroidGraphics.CENTER,startRec,0);
    g.drawText("HIGHscore",20,275,50,highRec,0);
    g.drawText("MORE APPS",g.getWidth() - 20,AndroidGraphics.RIGHT,moreRec,0);
    if (Settings.soundEnabled)
        g.drawpixmap(Assets.buttons,new Rect(0,100,100),380,480));
    else
        g.drawpixmap(Assets.buttons,new Rect(100,200,new Rect(
                0,480));
}

drawText方法:

@Override
public void drawText(String text,int x,int y,int color,int size,int position,Rect bounds,int rotation) {
    if (position == LEFT)
        paint.setTextAlign(Paint.Align.LEFT);
    else if (position == CENTER)
        paint.setTextAlign(Paint.Align.CENTER);
    else if (position == RIGHT)
        paint.setTextAlign(Paint.Align.RIGHT);
    else
        return;
    paint.setColor(color);
    Typeface typeface = Typeface.createFromAsset(assets,"typewrite.TTF");
    paint.setTypeface(typeface);
    paint.setTextSize(size);
    if (bounds != null) {
        Rect rec = new Rect();
        paint.getTextBounds(text,text.length(),rec);
        bounds.bottom = y;
        bounds.top = y - rec.height();
        if (position == CENTER) {
            bounds.left = x - rec.width() / 2;
            bounds.right = x + rec.width() / 2;
        } else if (position == RIGHT) {
            bounds.left = x - rec.width();
            bounds.right = x;
        } else if (position == LEFT) {
            bounds.left = x;
            bounds.right = x + rec.width();
        } else
            return;
    }
    canvas.save();
    canvas.rotate(rotation,x,y);
    canvas.drawText(text,y,paint);
    canvas.restore();
}

解决方法

你某处有内存泄漏.有关可用于跟踪它的工具,请参阅开发人员文档中的 this blog post.另请参阅 this blog post以获取编程提示,以避免在Android应用程序中泄漏内存.

android – 我的logcat中的错误是什么?的更多相关文章

  1. READ_LOGS是正常或危险的Android权限吗?

    关于android.permission.READ_LOGSAndroid权限的使用,我收到的信息非常矛盾.首先,Android文档网站未指定此权限的保护级别.它既不是正常的,也不是危险的.他们确实指定了以下内容:“Notforusebythird-partyapplications,becauseLogentriescancontaintheuser’sprivateinformation.”一

  2. android – 如何找出服务(不在我的应用程序中)的启动意图?

    我想了解Google地图服务是如何自动启动的.当我转储主缓冲区或事件缓冲区的logcat时,我只能找出谷歌地图的哪个组件启动,但没有关于“谁”(包)启动它的线索,以及“如何”(意图)?有没有可用于查找它们的调试方法?解决方法我设法找到了“如何”,但仍然没有找到关于“谁”的线索.“怎么样”运行dumpsys活动服务,请参阅intent字段:

  3. android – 如何将LogCat输出到控制台?

    有没有办法让LogCat的输出出现在Eclipse的Console视图中?LogCat视图比Console更不方便,因为很难看到它中的长消息并且异常堆栈跟踪中没有可点击的突出显示以快速导航到错误源.只是为了说清楚–我希望有可点击的堆栈跟踪,就像普通的Eclipse控制台中那样,所以我可以快速导航到错误源.解决方法需要额外的步骤,但您可以复制并粘贴到控制台堆栈跟踪视图中,然后您可以获得可单击的链接.只需从Logcat中选择任意或所有行,将它们复制并粘贴到控制台中.

  4. 如何在Android Studio 1.0.0中更改logcat字体大小?

    我只找到了改变AndroidStudio中字体颜色的方法.解决方法Logcat只使用ConsoleFont的字体设置.要在AndroidStudio中更改此设置,请转到:Settings->Editor->Color&Fonts->ConsoleFont

  5. 当我切换设备时,Android Logcat没有显示日志

    我正在尝试使用Logcat来帮助诊断我的android问题.我经常插入手机并运行模拟器.有时我在模拟器上调试,有时我在手机上调试,甚至可能在第三个设备上调试.切换设备后,Logcat不会继续显示消息.如何在不重启eclipse的情况下指定Logcat执行的操作或强制它恢复日志记录?

  6. android – Logcat Message中pid,uid和gids的含义是什么?

    解决方法这些是标准的Linux术语:>pid=进程ID>uid=拥有该进程的应用程序的用户ID>gid=拥有该进程的应用程序的组ID

  7. android – 我的logcat中的错误是什么?

    我现在几乎完成了我的游戏,但今天我遇到了一个真正令人讨厌的问题.当我开始游戏并等待几分钟时,程序会自动关闭.而且我没有说明它.这是我的logcat显示的内容:我遗憾的是没有代码可以分享,因为我不知道程序崩溃了.编辑:绘图代码:drawText方法:解决方法你某处有内存泄漏.有关可用于跟踪它的工具,请参阅开发人员文档中的thisblogpost.另请参阅thisblogpost以获取编程提示,以避免在Android应用程序中泄漏内存.

  8. Android在TextView中显示Logcat

    我正在构建的应用程序具有对Android的root访问权限.我希望在其中一个TextView中显示Logcat日志信息,以便在我调试时它可以显示在屏幕上.有人可以给我一些想法,我可以调用哪些库/函数来访问这些日志?谢谢解决方法这是一个blogpost,完全符合您的需要.它有一个完整的代码示例,介绍如何显示Logcat日志的内容.这是代码:只是为了澄清,这不是我的答案,这里是original

  9. android – logcat与dmesg有什么区别?

    logcat使用什么日志源.dmesg日志是否包含在logcat的输出中?如果没有,dmesg日志和logcat日志之间有什么区别?

  10. android – 如何解决eclipse透视错误?

    我在下面的snap中添加了我的错误.我正在使用android并且我有EclipseIndigoServiceRelease1版本.当任何错误出现时它会给我java透视.如何关闭它并且只看到当我改变我的DDMS视角时,我停止它在java透视中.解决方法您可以通过转到Window–>来禁用自动logcat弹出窗口;偏好–>Android–>LogCat和取消选中当工作区中有来自应用程序的消息时显示lo

随机推荐

  1. bluetooth-lowenergy – Altbeacon库无法在Android 5.0上运行

    昨天我在Nexus4上获得了Android5.0的更新,并且altbeacon库停止了检测信标.似乎在监视和测距时,didEnterRegion和didRangeBeaconsInRegion都没有被调用.即使RadiusNetworks的Locate应用程序现在表现不同,一旦检测到信标的值,它们就不再得到更新,并且通常看起来好像信标超出了范围.我注意到的一点是,现在在logcat中出现以下行“B

  2. android – react-native动态更改响应者

    我正在使用react-native进行Android开发.我有一个视图,如果用户长按,我想显示一个可以拖动的动画视图.我可以使用PanResponder实现这一点,它工作正常.但我想要做的是当用户长按时,用户应该能够继续相同的触摸/按下并拖动新显示的Animated.View.如果您熟悉Google云端硬盘应用,则它具有类似的功能.当用户长按列表中的任何项目时,它会显示可拖动的项目.用户可以直接拖

  3. android – 是否有可能通过使用与最初使用的证书不同的证书对其进行签名来发布更新的应用程序

    是否可以通过使用与最初使用的证书不同的证书进行签名来发布Android应用程序的更新?我知道当我们尝试将这样的构建上传到市场时,它通常会给出错误消息.但有没有任何出路,比如将其标记为主要版本,指定市场中的某个地方?解决方法不,你不能这样做.证书是一种工具,可确保您是首次上传应用程序的人.所以总是备份密钥库!

  4. 如何检测Android中是否存在麦克风?

    ..所以我想在让用户访问语音输入功能之前检测麦克风是否存在.如何检测设备上是否有麦克风.谢谢.解决方法AndroidAPI参考:hasSystemFeature

  5. Android – 调用GONE然后VISIBLE使视图显示在错误的位置

    我有两个视图,A和B,视图A在视图B上方.当我以编程方式将视图A设置为GONE时,它将消失,并且它正下方的视图将转到视图A的位置.但是,当我再次将相同的视图设置为VISIBLE时,它会在视图B上显示.我不希望这样.我希望视图B回到原来的位置,这是我认为会发生的事情.我怎样才能做到这一点?编辑–代码}这里是XML:解决方法您可以尝试将两个视图放在RelativeLayout中并相对于彼此设置它们的位置.

  6. android – 获得一首歌的流派

    我如何阅读与歌曲相关的流派?我可以读这首歌,但是如何抓住这首歌的流派,它存放在哪里?解决方法检查此代码:

  7. android – 使用textShadow折叠工具栏

    我有一个折叠工具栏的问题,在展开状态我想在文本下面有一个模糊的阴影,我使用这段代码:用:我可以更改textColor,它可以工作,但阴影不起作用.我为阴影尝试了很多不同的值.是否可以为折叠文本投射阴影?

  8. android – 重用arm共享库

    我已经建立了armarm共享库.我有兴趣重用一个函数.我想调用该函数并获得返回值.有可能做这样的事吗?我没有任何头文件.我试过这个Android.mk,我把libtest.so放在/jni和/libs/armeabi,/lib/armeabi中.此时我的cpp文件编译,但现在是什么?我从objdump知道它的名字编辑:我试图用这个android.mk从hello-jni示例中添加prebuild库:它工作,但libtest.so相同的代码显示以下错误(启动时)libtest.so存在于libhello-j

  9. android – 为NumberPicker捕获键盘’Done’

    我有一个AlertDialog只有一些文本,一个NumberPicker,一个OK和一个取消.(我知道,这个对话框还没有做它应该保留暂停和恢复状态的事情.)我想在软键盘或其他IME上执行“完成”操作来关闭对话框,就像按下了“OK”一样,因为只有一个小部件可以编辑.看起来处理IME“Done”的最佳方法通常是在TextView上使用setonEditorActionListener.但我没有任何Te

  10. android – 想要在调用WebChromeClient#onCreateWindow时知道目标URL

    当我点击一个带有target=“_blank”属性的超链接时,会调用WebChromeClient#onCreateWindow,但我找不到新的窗口将打开的新方法?主页url是我唯一能知道的东西?我想根据目标网址更改应用行为.任何帮助表示赞赏,谢谢!

返回
顶部