2

WebSphere 7/IBM JDK 6 で奇妙な問題が発生しており、ノードの 1 つで初期化の問題が発生しています。

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 ループですが、次のステートメントは文字列連結であり、おそらくコンパイラによって 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-COMPILED STRING.GETCHARS THROWS UNEXPECTED ARRAYINDEXOUTOFBO UNDSEXCEPTION」を参照してください。

于 2013-04-17T13:06:18.457 に答える
0

上記のコードはnull、null 環境ハッシュテーブルを渡すと返されるようです。

これは、ある種の引数で InitialContext をインスタンス化しているのではないかと思います。

上記のコードが実際にソースである場合、null 環境ハッシュテーブルを渡すと、getURLContext() が短縮nullされ、文字列連結ループの前に返されます。

JNDI 環境変数を指定する必要がない場合 (たとえば、デフォルトの JNDI 環境変数を使用)を試してみることはできますnew InitialContext()か?new InitialContext(null)

于 2013-04-18T01:36:21.590 に答える