2

初めての cocos2d-x ゲームを終了しました。GNexus 4.1 およびその他の下位デバイス (タブレットを含む) でテストしました。ただし、Nexus 7 を購入してダウンロードすると、開くことさえできません。4.2 を実行していますが、それが問題でしょうか? どんな助けでも大歓迎です。クラッシュレポート:

java.lang.ExceptionInInitializerError
at java.lang.Class.newInstanceImpl(Native Method)
at java.lang.Class.newInstance(Class.java:1319)
at android.app.Instrumentation.newActivity(Instrumentation.java:1054)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
at android.app.ActivityThread.access$600(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5039)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.UnsatisfiedLinkError: Cannot load library:     soinfo_relocate(linker.cpp:975): cannot locate symbol "__exidx_end" referenced by               "libgame.so"...
at java.lang.Runtime.loadLibrary(Runtime.java:371)
at java.lang.System.loadLibrary(System.java:535)
at com.penguinproductions.classiclightcycles.<clinit>(classiclightcycles.java:107)
... 15 more
4

1 に答える 1

5

このエラーに苦しむ多くのアプリケーションがあります。特定のAndroid NDKを使用してコンパイルされたプロジェクトを使用してAndroid 4.2で発生します-私にとってはr8dでしたが、そのバグを持つ他のバージョンの人も見つけることができます. 私が見つけた回避策はここに記載されています。.cpp解決策は、任意のファイルに次のコード行を追加することです。

#ifdef __cplusplus
    extern "C" {
#endif

void __exidx_start() {}
void __exidx_end()   {}

#ifdef __cplusplus
    }
#endif

私にとってはうまくいきました。

ただし、NDK の将来のバージョンで最終的に修正されたときに、これらのシンボルが 2 回定義される可能性があるため、注意が必要だと思います。この回避策は、実際にはバグに変わります。

于 2013-01-24T13:02:41.773 に答える