Java StringBuilder:ArrayIndexOutOfBoundsException

Java StringBuilder:ArrayIndexOutOfBoundsException,java,websphere,stringbuilder,websphere-7,Java,Websphere,Stringbuilder,Websphere 7,我们在WebSphere7/IBMJDK6中遇到了一个奇怪的问题,其中一个节点有一些初始化问题 我们有一些调用InitialContext.lookup的代码,在这个节点上,我们有时会遇到以下异常: Caused by: java.lang.ArrayIndexOutOfBoundsException at java.lang.String.getChars(String.java:666) at java.lang.StringBuilder.append(

我们在WebSphere7/IBMJDK6中遇到了一个奇怪的问题,其中一个节点有一些初始化问题

我们有一些调用InitialContext.lookup的代码,在这个节点上,我们有时会遇到以下异常:

Caused by: java.lang.ArrayIndexOutOfBoundsException
         at java.lang.String.getChars(String.java:666)
         at java.lang.StringBuilder.append(StringBuilder.java:207)
         at javax.naming.spi.NamingManager.getURLContext(NamingManager.java:646)
         at javax.naming.InitialContext.getURLOrDefaultInitCtx(InitialContext.java:422)
         at javax.naming.InitialContext.lookup(InitialContext.java:436)
         [...]
我们查看了javax.naming.spi.NamingManager.getURLContext的源代码:

public static Context getURLContext(String schema, Hashtable<?, ?> envmt)
        throws NamingException {

    if (null == schema || 0 == schema.length() || null == envmt) {
        return null;
    }

    // obtain pkg prefixes from hashtable
    String pkgPrefixes[] = EnvironmentReader
            .getFactoryNamesFromEnvironmentAndProviderResource(envmt, null,
                    Context.URL_PKG_PREFIXES);

    for (String element : pkgPrefixes) {
        // create factory instance
        ObjectFactory factory;
        String clsName = element + "." //$NON-NLS-1$
                + schema + "." //$NON-NLS-1$
                + schema + "URLContextFactory"; //$NON-NLS-1$
    [...]

这是IBMJVM的JIT编译器的一个已知错误。解决方法似乎是从JIT编译中排除
getChars

-Xjit:exclude={ProgramClass.callStringGetChars*}

请参阅以获取参考。

如果传递空环境哈希表,则上面的代码似乎返回空

这让我想知道您是否正在用某种参数实例化InitialContext

如果上面的代码确实是源代码,则传递null环境哈希表将使getURLContext()短路,以在字符串串联循环之前返回
null


如果您不需要指定JNDI环境变量(例如,使用默认JNDI环境),是否可以尝试
new InitialContext()
new InitialContext(null)

您是否尝试设置断点以查看实际发生的情况?太晚了,问题节点已经重新启动-/你没有测试系统吗?;-|您能另外发布您提到的for循环的代码吗?它发生在测试系统上。;-)但我不确定故意让其中一个节点再次处于该状态有多容易。@user714965请参阅我的更新问题谢谢,我将仔细检查我们的版本。问题是:“此缺陷将在:6.0.0 SR9中修复。JIT编译器已更新以更正其算法。。要获得修复,请安装build 20100622或更高版本”所以我们应该有这个修正(请参阅我编辑的问题,其中提到了我们使用的java版本),我仍然不知道为什么我们使用的版本不包含这个修正,但我想这个答案是正确的,所以我接受它。我们使用的是无参数构造函数。如果envmt为null,我认为这与堆栈跟踪不匹配。
-Xjit:exclude={ProgramClass.callStringGetChars*}