gpt4 book ai didi

android - 如何在运行时android期间获取堆栈跟踪

转载 作者:塔克拉玛干 更新时间:2023-11-01 21:28:31 24 4
gpt4 key购买 nike

我的应用未按预期运行。在设备进入休眠状态(黑屏)并打开后,设备显示我的应用程序的屏幕,但片刻之后屏幕的一部分消失了 - 工具栏下方的选项卡式 viewpager。

我在我的应用程序正在执行任何操作并且屏幕仍然正常的最后一点设置了一个断点,所以这是系统正在执行的操作,但我不知道是什么操作。

有没有办法打开堆栈跟踪,以便记录系统从那时起使用的方法,也许这会让我找出选项卡式 viewpager 消失的原因?

我应该提一下,该应用程序仍在正常运行,我能够从工具栏打开抽屉导航并使用它的所有功能,但我再也看不到选项卡式 viewpager,直到我重新创建它。

最佳答案

如果您能够正确取回日志,则很可能问题已得到解决。正如其他人提到的,logcat 是一个不错的选择。

完善的解决方案可以是一个高效的记录器系统,它将捕获所有日志。您可以将这些写入本地文件以供将来引用。

JakeWharton's Hugo 是一个非常棒的库,您只需要使用注释 @DebugLog 进行少量修改。这将捕获您的应用程序日志并在 logcat 中打印。

你的bundle.gradle (Module:app)应该修改如下

apply plugin: 'com.android.application'
apply plugin: 'hugo'
android {
compileSdkVersion 24
buildToolsVersion "23.0.3"
....... Other configurations

bundle.gradle (Project) 中,这些应该存在

buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.1.2'
classpath 'com.jakewharton.hugo:hugo-plugin:1.2.1'
}
}

为了让 hugo 跟踪您的应用程序日志,需要添加 @DebugLog。例如,在您的类方法中。您可以在 hugo sample 中找到它

现在为了取回日志,请执行以下操作。

The following code does not have to do anything with hugo library, it will just capture logs from logcat.

Inside 和 AsyncTask 执行以下操作并将内容写入文件并进行验证。

        @Override
protected String doInBackground(Void... voids) {
String responseString = null;

try {

Process process = Runtime.getRuntime().exec("logcat -b main -d");
BufferedReader bufferedReader = new BufferedReader(
new InputStreamReader(process.getInputStream()));
String line;
StringBuilder log=new StringBuilder();
while ((line = bufferedReader.readLine()) != null) {

log.append(line);
log.append('\n');
log.append("-----------");
}
responseString = log.toString();

} catch (Exception e) {
}
return responseString;
}

它可能看起来很复杂,但相信我,它比其他库足够好,并且简化了开发人员的工作。

您也可以尝试使用 Runtime.getRuntime().exec("logcat -d");

祝你好运,试试吧。 !!

关于android - 如何在运行时android期间获取堆栈跟踪,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38786028/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com