Android - 无法解析java.lang.StringIndexOutOfBoundsException

时间:2015-07-14 19:17:56

标签: java android eclipse error-handling

我无法找到解决方案,甚至找不到此错误的原因。 Eclipse中的相​​同代码(用于测试)中不存在此错误,但在Android Studio应用程序中使用时会发生错误。

来自Logcat:

 java.lang.IllegalStateException: Could not execute method of the activity
            at android.view.View$1.onClick(View.java:4020)
            at android.view.View.performClick(View.java:4780)
            at android.view.View$PerformClick.run(View.java:19866)
            at android.os.Handler.handleCallback(Handler.java:739)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5257)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
     Caused by: java.lang.reflect.InvocationTargetException
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at android.view.View$1.onClick(View.java:4015)
            at android.view.View.performClick(View.java:4780)
            at android.view.View$PerformClick.run(View.java:19866)
            at android.os.Handler.handleCallback(Handler.java:739)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5257)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
     Caused by: java.lang.ExceptionInInitializerError
            at com.bmc.thirdparty.org.apache.commons.lang.builder.ToStringStyle$MultiLineToStringStyle.<init>(ToStringStyle.java:2135)
            at com.bmc.thirdparty.org.apache.commons.lang.builder.ToStringStyle.<clinit>(ToStringStyle.java:79)
            at java.lang.Class.classForName(Native Method)
            at java.lang.Class.forName(Class.java:309)
            at java.lang.Class.forName(Class.java:273)
            at com.bmc.arsys.api.Config.if(Unknown Source)
            at com.bmc.arsys.api.Config.applyDefaults(Unknown Source)
            at com.bmc.arsys.apitransport.ApiConfig.<init>(Unknown Source)
            at com.bmc.arsys.api.Config.<init>(Unknown Source)
            at com.bmc.arsys.api.Config.<clinit>(Unknown Source)
            at com.bmc.arsys.api.session.a.a(Unknown Source)
            at com.bmc.arsys.api.session.a.<init>(Unknown Source)
            at com.bmc.arsys.api.ARServerUser.<clinit>(Unknown Source)
            at flashmanagment.app.ARS.initializeServer(ARS.java:41)
            at flashmanagment.app.MainActivity.loadData(MainActivity.java:51)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at android.view.View$1.onClick(View.java:4015)
            at android.view.View.performClick(View.java:4780)
            at android.view.View$PerformClick.run(View.java:19866)
            at android.os.Handler.handleCallback(Handler.java:739)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5257)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
     Caused by: java.lang.StringIndexOutOfBoundsException: length=1; regionStart=0; regionLength=3
            at java.lang.String.startEndAndLength(String.java:504)
            at java.lang.String.substring(String.java:1333)
            at com.bmc.thirdparty.org.apache.commons.lang.SystemUtils.getJavaVersionAsFloat(SystemUtils.java:1122)
            at com.bmc.thirdparty.org.apache.commons.lang.SystemUtils.<clinit>(SystemUtils.java:818)
            at com.bmc.thirdparty.org.apache.commons.lang.builder.ToStringStyle$MultiLineToStringStyle.<init>(ToStringStyle.java:2135)
            at com.bmc.thirdparty.org.apache.commons.lang.builder.ToStringStyle.<clinit>(ToStringStyle.java:79)
            at java.lang.Class.classForName(Native Method)
            at java.lang.Class.forName(Class.java:309)
            at java.lang.Class.forName(Class.java:273)
            at com.bmc.arsys.api.Config.if(Unknown Source)
            at com.bmc.arsys.api.Config.applyDefaults(Unknown Source)
            at com.bmc.arsys.apitransport.ApiConfig.<init>(Unknown Source)
            at com.bmc.arsys.api.Config.<init>(Unknown Source)
            at com.bmc.arsys.api.Config.<clinit>(Unknown Source)
            at com.bmc.arsys.api.session.a.a(Unknown Source)
            at com.bmc.arsys.api.session.a.<init>(Unknown Source)
            at com.bmc.arsys.api.ARServerUser.<clinit>(Unknown Source)
            at flashmanagment.app.ARS.initializeServer(ARS.java:41)
            at flashmanagment.app.MainActivity.loadData(MainActivity.java:51)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at android.view.View$1.onClick(View.java:4015)
            at android.view.View.performClick(View.java:4780)
            at android.view.View$PerformClick.run(View.java:19866)
            at android.os.Handler.handleCallback(Handler.java:739)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5257)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)

这是我从bmc导入的库的错误吗?

主要活动的相关代码,从按钮点击调用:

   public void loadData(View v){
        ARS.getInstance().initializeServer("username","password");   
    }   

来自Java Class:

public class ARS {

public static ARS instance = new ARS();

public static ARServerUser server;
public static ARS getInstance(){
    return instance;
}

public void initializeServer(String user, String password){
    server = new ARServerUser(user,password,null,"serverStringHere",portNumberHere);

}

同样,在Eclipse中使用了相同的代码而没有错误。任何帮助都会非常感激。

编辑SystemUtils.java:1122

    1118    private static float More ...getJavaVersionAsFloat() {
1119        if (JAVA_VERSION_TRIMMED == null) {
1120            return 0f;
1121        }
1122        String str = JAVA_VERSION_TRIMMED.substring(0, 3);
1123        if (JAVA_VERSION_TRIMMED.length() >= 5) {
1124            str = str + JAVA_VERSION_TRIMMED.substring(4, 5);
1125        }
1126        try {
1127            return Float.parseFloat(str);
1128        } catch (Exception ex) {
1129            return 0;
1130        }
1131    }

2 个答案:

答案 0 :(得分:0)

您应该提供有关您的程序的更多信息,因为此代码不是完整的图片。您正在尝试调用按钮单击,但您的应用程序未处于正确状态。

答案 1 :(得分:0)

这看起来像是库有一些关于Java版本格式的假设的问题,这两种环境在Eclipse和Android Studio之间必须有所不同。

变量/常量JAVA_VERSION_TRIMMED已经设置为长度为1的东西,但是库假设它更长。

要进一步调试,您应该在SystemUtils第818行的静态初始化程序块中设置断点,否则检查该行上发生的情况。

一旦显示,您的选择将有所不同。可能是您无法影响库的情况。虽然Apache Commons Lang是开源的并且有可能做出贡献,但您可能会发现通过BMC库路由这些更改更加困难。