Memory safety requirements

Duchess provides a safe abstraction atop the Java Native Interface (JNI). This means that, as long as you are using Duchess to interact with the JVM, you cannot cause memory unsafety. However, there are edge cases that can "void" this guarantee and which Duchess cannot control.

Memory safety requirements

Duchess will guarantee memory safety within your crate, but there are two conditions that it cannot by itself guarantee:

  • You must build with the same Java class files that you will use when you deploy:
    • Part of how Duchess guarantees is safety is by reflecting on .class files at build time.
    • If you build against one set of class files then deploy with another,
  • You must be careful when mixing Duchess with other Rust JNI libraries: (e.g., the jni crate or robusta_jni)
    • For the most part, interop between Duchess and other JNI crates should be no problem. But there are some particular things that can cause issues:
      • The JVM cannot be safely started from multiple threads at once. Duchess uses a lock to avoid contending with itself but we cannot protect from other libraries starting the JVM in parallel with us. It is generally best to start the JVM yourself (via any means) in the main function or some other central place so that you are guaranteed it happens once and exactly once. Duchess should work just fine if the JVM has been started by another crate.