我无法找到解决方案,甚至找不到此错误的原因。 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 }
答案 0 :(得分:0)
您应该提供有关您的程序的更多信息,因为此代码不是完整的图片。您正在尝试调用按钮单击,但您的应用程序未处于正确状态。
答案 1 :(得分:0)
这看起来像是库有一些关于Java版本格式的假设的问题,这两种环境在Eclipse和Android Studio之间必须有所不同。
变量/常量JAVA_VERSION_TRIMMED
已经设置为长度为1的东西,但是库假设它更长。
要进一步调试,您应该在SystemUtils第818行的静态初始化程序块中设置断点,否则检查该行上发生的情况。
一旦显示,您的选择将有所不同。可能是您无法影响库的情况。虽然Apache Commons Lang是开源的并且有可能做出贡献,但您可能会发现通过BMC库路由这些更改更加困难。