• Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
  • Asset Store
  • Get Unity

UNITY ACCOUNT

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account
  • Blog
  • Forums
  • Answers
  • Evangelists
  • User Groups
  • Beta Program
  • Advisory Panel

Navigation

  • Home
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
    • Blog
    • Forums
    • Answers
    • Evangelists
    • User Groups
    • Beta Program
    • Advisory Panel

Unity account

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account

Language

  • Chinese
  • Spanish
  • Japanese
  • Korean
  • Portuguese
  • Ask a question
  • Spaces
    • Default
    • Help Room
    • META
    • Moderators
    • Topics
    • Questions
    • Users
    • Badges
  • Home /
avatar image
1
Question by EvgenyPol · Sep 14, 2018 at 12:18 PM · errorpluginjavajni

JNI error when calling Java plugin from System.AppDomain.CurrentDomain.UnhandledException callback handler

Hello everyone, when I try to access my Java plugin from application's unhandled exception callback I'm getting the following errors and my application freezes:

 JNI ERROR (app bug): accessed stale Local 0x9  (index 0 in a table of size 0)
 JNI DETECTED ERROR IN APPLICATION: use of deleted local reference 0x9

Here is my C# script, attached to one of the game objects:

 using UnityEngine;
 using System.Threading;
 using System;

 public class PlayerController : MonoBehaviour
 {
     void Start()
     {
         AppDomain.CurrentDomain.UnhandledException += OnHandleUnresolvedException;

         using (var javaClass = new AndroidJavaClass("MyJavaClass"))
         {
             var str = javaClass.CallStatic<string>("GetString");
             Debug.Log("String from Java class: " + str);
         }

         new Thread(() =>
         {
             Thread.Sleep(10000);
             object obj = null;
             obj.ToString();
         }).Start();
     }

     private static void OnHandleUnresolvedException(object sender, UnhandledExceptionEventArgs e)
     {
         var message = ((Exception)e.ExceptionObject).Message;
         Debug.Log("Unhandled exception: " + message);

         using (var javaClass = new AndroidJavaClass("MyJavaClass"))
         {
             javaClass.CallStatic("ErrorOccurred", message);
         }
     }
 }

And here is the Java plugin source code. It is added to Unity project as a simple ".java" file in the assets folder, plugin import settings are correctly configured ("Android" checkbox checked):

 import android.util.Log;

 public class MyJavaClass
 {
     public static void ErrorOccurred(String message)
     {
         Log.e("TAG", message);
     }

     public static String GetString()
     {
         return "test";
     }
 }

When I start my application on Android emulator I see the following messages in the Logcat window:

 I/Unity: String from Java class: test
 I/Unity: Unhandled exception: Object reference not set to an instance of an object
 E/zygote: JNI ERROR (app bug): accessed stale Local 0x9  (index 0 in a table of size 0)
 A/zygote: java_vm_ext.cc:534] JNI DETECTED ERROR IN APPLICATION: use of deleted local reference 0x9

Any tips will be greatly appreciated!

Comment
Add comment · Show 1
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users
avatar image Max-Pixel · Mar 20, 2019 at 01:25 AM 0
Share

Did you ever end up figuring this out?

0 Replies

· Add your reply
  • Sort: 

Your answer

Hint: You can notify a user about this post by typing @username

Up to 2 attachments (including images) can be used with a maximum of 524.3 kB each and 1.0 MB total.

Welcome to Unity Answers

If you’re new to Unity Answers, please check our User Guide to help you navigate through our website and refer to our FAQ for more information.

Before posting, make sure to check out our Knowledge Base for commonly asked Unity questions.

Check our Moderator Guidelines if you’re a new moderator and want to work together in an effort to improve Unity Answers and support our users.

Follow this Question

Answers Answers and Comments

123 People are following this question.

avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image

Related Questions

Now that Unity 4.1.2 broke the Android plugin examples, what do you use to learn them? 1 Answer

EntryPointNotFoundException, when trying to import DLL. Help please :) 1 Answer

How to pass an interface to Java from Unity code? 2 Answers

How to write a java lib for unity as a plugin to make run another android app? 1 Answer

error CS1704: An assembly with the same simple name 'Editor' has already been imported. Try removing one of the references or sign them to enable side-by-side. 0 Answers


Enterprise
Social Q&A

Social
Subscribe on YouTube social-youtube Follow on LinkedIn social-linkedin Follow on Twitter social-twitter Follow on Facebook social-facebook Follow on Instagram social-instagram

Footer

  • Purchase
    • Products
    • Subscription
    • Asset Store
    • Unity Gear
    • Resellers
  • Education
    • Students
    • Educators
    • Certification
    • Learn
    • Center of Excellence
  • Download
    • Unity
    • Beta Program
  • Unity Labs
    • Labs
    • Publications
  • Resources
    • Learn platform
    • Community
    • Documentation
    • Unity QA
    • FAQ
    • Services Status
    • Connect
  • About Unity
    • About Us
    • Blog
    • Events
    • Careers
    • Contact
    • Press
    • Partners
    • Affiliates
    • Security
Copyright © 2020 Unity Technologies
  • Legal
  • Privacy Policy
  • Cookies
  • Do Not Sell My Personal Information
  • Cookies Settings
"Unity", Unity logos, and other Unity trademarks are trademarks or registered trademarks of Unity Technologies or its affiliates in the U.S. and elsewhere (more info here). Other names or brands are trademarks of their respective owners.
  • Anonymous
  • Sign in
  • Create
  • Ask a question
  • Spaces
  • Default
  • Help Room
  • META
  • Moderators
  • Explore
  • Topics
  • Questions
  • Users
  • Badges