忍者ブログ
  • 2024.10
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 2024.12
[PR]
×

[PR]上記の広告は3ヶ月以上新規記事投稿のないブログに表示されています。新しい記事を書く事で広告が消えます。

【2024/11/23 07:10 】 |
JNIでattempt to use stale local reference 0x1
JNIで

attempt to use stale local reference 0x1


というエラーが出た。

ググってみると、無効になったクラスにアクセスしてるとか、解放された変数に参照しているみたいなことが書いてある。
参考
参考

でも、そんな単純ミスはしていない。
おかしい。

その少し前のワーニングで、
trying to work around app JNI bugs, but didn't find 0xXXXXXXXX in table!
DeleteLocalRef(0xXXXXXXXX) failed to find entry
というようなのが出ている。

で、このポインタが示す変数はなんぞや、というのを出力して見てみたところ、
C++変数から変換したJNIオブジェクトだった。
特に何の問題もなさそう。


さらに発見したのが、

jobject objResult = methodInfo.env->CallStaticObjectMethod(methodInfo.classID , methodInfo.methodID, jarg);


の戻り値のobjResultが0x1になっている。
エラーはこの変数にアクセスした瞬間起きたようだ。


しかし、メソッドシグネチャーも合っているし、なぜ戻り値がこんなことになるのか。



このコードのどこに問題があるのか。


こういう不可解なことが起きるときはスレッドが絡んでいるもの。
そうすると真の原因はここでないまったく別の場所にある可能性がある。

ということで、ともかく例外を出力させてみる。

if (methodInfo.env->ExceptionCheck()) {
methodInfo.env->ExceptionDescribe();
}



すると…

05-25 13:04:16.466: W/System.err(15337): java.lang.IllegalStateException: isLoaded must be called on the main UI thread.



案の定、スレッドのエラーだった。
発生箇所とはこことは無関係の場所。


ここを直したら、無事に動いた。
PR
【2015/05/25 13:28 】 | Android | 有り難いご意見(0)
<<cocos2d-xでAndroidでBGMが2度目以降再生されない | ホーム | JNIで不具合起きたら>>
有り難いご意見
貴重なご意見の投稿














<<前ページ | ホーム | 次ページ>>