当前位置: 首页 > 知识库问答 >
问题:

奇怪的logcat:如何修复?

宗政霄
2023-03-14

要查看Busybox的版本,请使用以下代码

公共字符串busybox_v()引发IOException{

Process p =Runtime.getRuntime().exec("busybox");
    InputStream a = p.getInputStream();
    InputStreamReader read = new InputStreamReader(a);
    BufferedReader in = new BufferedReader(read);
    StringBuilder buffer = new StringBuilder();

    String line = null;

    try {

        while ((line = in.readLine()) != null) {
            buffer.append(line);
        }

    } finally {
        read.close();
        in.close();
    }

    String result = buffer.toString().substring(0, 15);
    return result;

}

在大多数手机中工作正常,但在Nexus4中,他们给我发送了这个日志

java.lang.StringIndexOutOfBoundsException:长度=0;regionStart=0;regionLength=15在java.lang.String.StartAndLength(String.java:583)在java.lang.String.substring(String.java:1464)在com.MyPackage.MyApplicationName.Root.busybox_v(Root.java:98)在com.MyPackage.MyApplicationName.PageFragment$1.onClick(PageFragment.java:101)在android.view.view.performClick(view.java:4240)上在android.os.Handler.dispatchMessage(Handler.java:92)在android.os.Looper.loop(Looper.java:137)在android.app.ActivityThread.main(ActivityThread.java:5103)在java.lang.reflect.Method.invokenactive(本机方法)在android.view.view.view.view$PerformClick.run(view.java:17721)在android.os.os.Handler.Handler.java:730)在android.os.os.osjava.lang.reflect.Method.invoke(Method.java:525)位于com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)位于de.robv.android.xposed.xposed.XposedBridge.main(XposedBridge.java:110)位于dalvik.system.NativeStart.main(本机方法)

第98行对应于while的右括号。我不明白如何解决这个问题。要帮忙吗?

共有1个答案

宰父飞翼
2023-03-14

您的问题很可能是您的StringBuffer没有16个字符。你可以尝试这样的方法:

String result = buffer.toString().substring(0, Math.min(buffer.length()-1,15));

要知道更多,问题就变成了结果试图做什么?如果是十六进制代码,那么在这种情况下,您可能应该在前面附加0。如果它是一个字符串,可能会附加空格。底线是,若你们并没有输入16个字符,你们应该弄清楚该怎么做,并采取适当的行动。这可以通过以下方式实现:

if (buffer.length()>=16)
{
    String result = buffer.toString().substring(0, 15);
}
else
{
    //Do something here to manage the exception
}
 类似资料:
  • 我有以下代码来解析一个JSON文件: 要处理以下JSON文件: 如果我执行此代码,我将收到以下错误: 所以我开始一步一步地调试应用程序,看看part processing()中的哪个代码部分抛出了这个异常。令人惊讶的是,那里的所有代码都正常执行:没有抛出异常,也没有返回结果I except。 更让我惊讶的是,当我稍微改变第一种方法的代码时,它可以在不产生异常的情况下工作。 我不知道println方

  • 我从凯拉斯搬到了皮托克。我对搬到CUDA这件事很陌生。我花了好几个小时在网上冲浪,却什么都没找到?修复可能是一两行。如果有人知道如何解决这个问题,我会很感激的? 下面是我的代码,首先我将我的u-net模型定义为一个nn类。类似于以下代码的模块: 然后我像下面的代码一样运行我的unet。请注意,在定义模块时,我将其设置为cuda。我还将输入数据及其标签设置为cuda。 但是我得到了这个错误: Run

  • 问题内容: 我在GregorianCalendar类中遇到一个奇怪的行为,我想知道我是否真的做得不好。 仅当初始化日期的月份的实际Maximum大于我将日历设置为的月份时,才追加此值。 这是示例代码: 我知道问题是由于日历初始化日期是31天(可能是5月),与设置为2月(28天)的月份混淆了。修复很容易(只需在设置年和月之前将day_of_month设置为1),但是我想知道这确实是想要的行为。有什么

  • 问题内容: 我正在为一个问题而苦苦挣扎,我不明白为什么它不起作用。如何通过将变量传递并转换为? 为什么在顶部代码段中不起作用,但在行下方的底部代码段中起作用? 唯一的区别似乎是添加了一个额外的变量,该变量也被键入为? 问题答案: 该是一种原始类型,同时是一个普通的Java类。您不能在原始类型上调用方法。但是该方法在上可用,如javadoc中所示 有关这些原始类型的更多信息,请参见此处

  • 问题内容: 为什么的到哪里去了? 问题答案: 删除任何字符,并从字符串的开头和结尾。

  • 问题内容: 我正在使用此代码: 但是在编译时出现此错误: 然后是堆栈跟踪的编译器错误。 我将在课堂开始时同时进行这两种导入: 有什么事吗 在Netbeans中,我看到自动完成选项并且Locale对象没有语法错误… 问题答案: 您的设置有些麻烦,下面的程序对我来说很好用。 它要求源代码的事实使我相信它正在尝试以某种调试模式进行编译或运行。您不需要编译java.util。*的源代码,这很奇怪。 看看我