1

引数を期待するメイン メソッドを持つ Java クラスがあります。引数なしでクラスを実行すると、このようなエラーが発生します。これは、Java がクラスを見つけて実行し、ランタイム ArrayIndexOutOfBoundsException を生成することを意味します。

zookeeper@zookeeper-virtual-machine:~/zookeeper-3.4.5$ java -cp .:zookeeper-3.4.5.jar org.zookeeper.LsGroup
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 0
    at org.zookeeper.LsGroup.main(LsGroup.java:50)

しかし、必要なコマンド ライン引数 ( zookeeper@zookeeper-virtual-machine:~/zookeeper-3.4.5$ java -cp .:zookeeper-3.4.5.jar org.zookeeper.LsGroup Test) を指定して同じステートメントを実行すると、クラスが見つからないというエラーが発生します。

zookeeper@zookeeper-virtual-machine:~/zookeeper-3.4.5$ java -cp .:zookeeper-3.4.5.jar org.zookeeper.LsGroup Test
Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory
    at org.apache.zookeeper.ZooKeeper.<clinit>(ZooKeeper.java:94)
    at org.zookeeper.LsGroup.connect(LsGroup.java:19)
    at org.zookeeper.LsGroup.main(LsGroup.java:50)
Caused by: java.lang.ClassNotFoundException: org.slf4j.LoggerFactory
    at java.net.URLClassLoader$1.run(URLClassLoader.java:217)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:205)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:321)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:266)
    ... 3 more
zookeeper@zookeeper-virtual-machine:~/zookeeper-3.4.5$ 

今朝も同様の問題がありましたが、そのスレッドの特定の問題は解決されました。 Java がクラスを見つけられないのはなぜですか?

コマンドライン引数を渡すと、クラスが見つからないというエラーが発生するのはなぜですか? どうすればこれを修正できますか?

これはJavaコードです:

package org.zookeeper;
import java.io.IOException;
import java.util.List;
import java.util.concurrent.CountDownLatch;

import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.Watcher.Event.KeeperState;

public class LsGroup implements Watcher {

    private static final int SESSION_TIMEOUT = 5000;
    private ZooKeeper zk;
    private CountDownLatch connectedSignal = new CountDownLatch(1);

    public void connect(String hosts) throws IOException, InterruptedException {
        zk = new ZooKeeper(hosts, SESSION_TIMEOUT, this);
        connectedSignal.await();
    }

    @Override
    public void process(WatchedEvent event) { // Watcher interface
        if (event.getState() == KeeperState.SyncConnected) {
            connectedSignal.countDown();
        }
    }

    public void ls(String groupName) throws KeeperException, InterruptedException {
        String path = "/" + groupName;
        try {
            List<String> children = zk.getChildren(path, false);
            for (String child : children) {
                System.out.println(path+"/"+child);
                System.out.println(zk.getChildren(path +"/"+ child, false));
            }
        } catch (KeeperException.NoNodeException e) {
            System.out.printf("Group %s does not exist\n", groupName);
            System.exit(1);
        }
    }

    public void close() throws InterruptedException {
        zk.close();
    }

    public static void main(String[] args) throws Exception {
        LsGroup lsGroup = new LsGroup();
        lsGroup.connect(args[0]);
        lsGroup.ls(args[1]);
        lsGroup.close();
    }
}
4

3 に答える 3

7

あなたのZooKeeperクラスは に依存しているようslf4jです。コマンドライン引数を指定しない場合、この行は

lsGroup.connect(args[0]);

あなたが見るもので失敗しArrayIndexOutOfBoundsExceptionます。このため、ZooKeeperクラスが初期化されることはなく、依存関係slf4jが JVM によって解決されることはありません。

コマンドライン引数を指定する場合。JVM はクラスをロードしようとしますがslf4j、クラスパスにないため失敗します。関連する jar をクラスパスに追加する必要があります。

于 2013-11-12T19:32:44.547 に答える
0

すべての API jar を 1 つのディレクトリにまとめます

Linux環境で以下のオプションを使用してください

java -cp 'PATH_TO_DIR/*' クラス名

于 2013-11-12T19:42:35.587 に答える
0

Java クラスパスに slf4j 実装がありません (slf4j.jar だと思います)。

この jar は JAR にバンドルされていますか? それとも、この JAR はクラスパスのどこかにありますか?

クラスを実行するには、すべてのクラスの依存関係を提供する必要があります

于 2013-11-12T19:33:41.337 に答える