2

へい。

vim で lwjgl を使用してゲームをプログラミングしており、jdb でデバッグしようとしていますが、いくつか問題があります。

まず、私のプロジェクトのツリーを示します。(メイン クラスは Engine.java です)。

.
├── build
│   ├── classes
│   │   └── com
│   │       └── ionsoft
│   │           ├── engine
│   │           │   ├── Draw.class
│   │           │   ├── Engine.class
│   │           │   └── Timer.class
│   │           └── game
│   │               └── Game.class
│   └── jar
│       └── Jump2Box.jar
├── build.properties
├── build.xml
├── lib
│   ├── jars
│   │   ├── lwjgl.jar
│   │   ├── lwjgl_util.jar
│   │   └── slick-util.jar
│   └── natives-linux
│       ├── libjinput-linux64.so
│       ├── libjinput-linux.so
│       ├── liblwjgl64.so
│       ├── liblwjgl.so
│       ├── libopenal64.so
│       └── libopenal.so
├── LICENCE
├── README
├── src
│   └── com
│       └── ionsoft
│           ├── engine
│           │   ├── Draw.java
│           │   ├── Engine.java
│           │   └── Timer.java
│           └── game
│               └── Game.java
└── tags

javac デバッグ オプションを使用して ant でプロジェクトをコンパイルしています。build.xml ファイルのコンパイルの部分は次のとおりです。

<!-- Compile -->
<target name="compile">
    <mkdir dir="${classes.dir}" /> 
    <javac srcdir="${src.dir}" destdir="${classes.dir}" classpathref="classpath" debug="true" includeantruntime="false" />
</target>   

アプリケーションをデバッグしようとすると、問題が発生します。manページを読んだところ、classpath オプションがあることがわかりました。私は lwjgl を使用しているので、.class ファイルへのパスを含める必要があると思います。

プロジェクトのルートからこのコードを実行しています。

ruby@Cedrus ~/development/java/projects/Jump2Box $ jdb -classpath build/classes com.ionsoft.engine.Engine                                                    
Initializing jdb ...
> run
run com.ionsoft.engine.Engine
Set uncaught java.lang.Throwable
Set deferred uncaught java.lang.Throwable
> 
VM Started: 
Exception occurred: java.lang.ClassNotFoundException (uncaught)"thread=main", java.lang.ClassLoader.loadClass(), line=436 bci=121

main[1] cont
Exception in thread "main" > java.lang.NoClassDefFoundError: org/lwjgl/LWJGLException
    at java.lang.Class.getDeclaredMethods0(Native Method)
    at java.lang.Class.privateGetDeclaredMethods(Class.java:2521)
    at java.lang.Class.getMethod0(Class.java:2764)
    at java.lang.Class.getMethod(Class.java:1653)
    at sun.launcher.LauncherHelper.getMainMethod(LauncherHelper.java:494)
    at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:486)
Caused by: java.lang.ClassNotFoundException: org.lwjgl.LWJGLException
    at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 6 more

The application exited

この奇妙な例外にも気付きました。

Set uncaught java.lang.Throwable
Set deferred uncaught java.lang.Throwable

解決策を説明するこの投稿を見つけました。

ignore uncaught java.lang.Throwable

これを解決するために、このコード行をどこに置く必要があるのか​​ わかりません。lwjgl の .class も含める必要がありますか? 何が間違っているのかわかりません。

アップデート:

クラスパスに lwjgl を含めましたが、今でもうまく機能しています。ソースファイルへのパスも含めました。

ruby@Cedrus ~/development/java/projects/Jump2Box $ jdb -launch -classpath build/classes/com/ionsoft/engine/:build/classes/com/ionsoft/game/:lib/jars/ -sourcepath src/com/ionsoft/engine/:src/com/ionsoft/game/ Engine
Set uncaught java.lang.Throwable
Set deferred uncaught java.lang.Throwable
Initializing jdb ...
> 
VM Started: No frames on the current call stack

main[1] stop in Engine.main
Deferring breakpoint Engine.main.
It will be set after the class is loaded.
main[1] cont
> 
Exception occurred: java.lang.NoClassDefFoundError (uncaught)"thread=main",java.lang.ClassLoader.loadClass(), line=436 bci=121

main[1] next
Excep> tion in thread "main" java.lang.NoClassDefFoundError: Engine (wrong name: com/ionsoft/engine/Engine)
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:792)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
    at java.net.URLClassLoader.access$100(URLClassLoader.java:71)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:482)

The application exited

JVM を jdb のサーバーとして実行しようとすると、同じエラーが表示されます。

JVM サーバーのセットアップ

ruby@Cedrus ~/development/java/projects/Jump2Box $ java -classpath build/classes/com/ionsoft/engine/:build/classes/com/ionsoft/game/:lib/jars/ -agentlib:jdwp=transport=dt_socket,address=localhost:8888,server=y,suspend=y Engine                                                                                     
Listening for transport dt_socket at address: 8888

jdb との接続

ruby@Cedrus ~/development/java/projects/Jump2Box $ jdb -sourcepath src/com/ionsoft/engine/:src/com/ionsoft/game/ -connect com.sun.jdi.SocketAttach:hostname=localhost,port=8888
Set uncaught java.lang.Throwable
Set deferred uncaught java.lang.Throwable
Initializing jdb ...
> 
VM Started: No frames on the current call stack

main[1] stop in Engine.main
Deferring breakpoint Engine.main.
It will be set after the class is loaded.
main[1] cont
> 
Exception occurred: java.lang.NoClassDefFoundError (uncaught)"thread=main",java.lang.ClassLoader.loadClass(), line=436 bci=121

main[1] list
Source file not found: ClassLoader.java
main[1] next
> 
The application exited

「例外が発生した」時点で、JVM は同じエラーを表示します。

Exception in thread "main" java.lang.NoClassDefFoundError: Engine (wrong name: com/ionsoft/engine/Engine)
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:792)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
    at java.net.URLClassLoader.access$100(URLClassLoader.java:71)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:482)

名前に問題があるようですが、解決方法がわかりません。

lwjgl で jar ファイルを実行する場合、ネイティブ ファイルを jar に添付する必要があります。私はantを使ってこの操作を行います。ここで私はこの操作を行うターゲットです。

<!-- Run generated jar -->
<target name="run" depends="jar">
    <java fork="true" classname="${main-class}">
     <classpath>
         <path refid="classpath" />
         <path location="${jar.dir}/${ant.project.name}.jar" />
     </classpath>
     <sysproperty key="java.library.path" value="${lwjgl_natives.dir}" />  </java>
</target>    

お時間をいただきありがとうございます。

4

2 に答える 2

1

この問題を解決するには、3 つのことを行う必要があります。

  1. クラスパスに lwjgl.jar へのパスを指定します。
  2. lwjgl ネイティブを挿入するための -Djava.library.path オプションを追加します。
  3. パッケージも使用して、クラスの完全な名前を使用します。元。com.ionsoft.engine.Engine

ここでは、JVM サーバーと JDB クライアントの作業コマンドを追加します。

# JVM server
java -classpath ./build/classes:./lib/jars/lwjgl.jar -Djava.library.path=./lib/natives-linux -agentlib:jdwp=transport=dt_socket,address=localhost:8888,server=y,suspend=y com.ionsoft.engine.Engine

# JDB client
jdb -sourcepath ./src -connect com.sun.jdi.SocketAttach:hostname=localhost,port=8888

これが誰かを助けることを願っています。

于 2013-11-10T11:55:50.800 に答える