2

我们在使用 WebSphere 7/IBM JDK 6 时遇到了一个奇怪的问题,其中一个节点有一些初始化问题。

我们有一些调用 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$
    [...]

第 646 行是增强的 for 循环,但下一条语句是 String 连接,可能会被编译器替换为 StringBuilder。

我们对 StringBuilder 进行了一些快速的单元测试,但无法引发 ArrayIndexOutOfBoundsException。

如何在这里抛出 ArrayIndexOutOfBoundsException 以及如何避免它?

编辑

我们正在使用以下 java 版本:

java version "1.6.0"
Java(TM) SE Runtime Environment (build pxa6460sr9fp2ifix-20110913_02(SR9 FP2+IV03622+IZ99243))
IBM J9 VM (build 2.4, JRE 1.6.0 IBM J9 2.4 Linux amd64-64 jvmxa6460sr9-20110912_90359 (JIT enabled, AOT enabled)
J9VM - 20110912_090359
JIT  - r9_20101028_17488ifx31
GC   - 20101027_AA)
JCL  - 20110727_04
4

2 回答 2

2

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

-Xjit:exclude={ProgramClass.callStringGetChars*}

请参阅IZ78413:JIT 编译的 STRING.GETCHARS 抛出 UNEXPECTED ARRAYINDEXOUTOFBO UNDSEXCEPTION以供参考。

于 2013-04-17T13:06:18.457 回答
0

null如果您传递一个空环境哈希表,上面的代码似乎会返回。

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

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

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

于 2013-04-18T01:36:21.590 回答