mirror of
https://github.com/zebrajr/opencv.git
synced 2026-01-15 12:15:17 +00:00
Introduce option to generate Java code with finalize() or Cleaners interface #28159 Closes https://github.com/opencv/opencv/issues/22260 Replaces https://github.com/opencv/opencv/pull/23467 The PR introduce configuration option to generate Java code with Cleaner interface for Java 9+ and old-fashion finalize() method for old Java and Android. Mat class and derivatives are manually written. The PR introduce 2 base classes for it depending on the generator configuration. Pros: 1. No need to implement complex and error prone cleaner on library side. 2. No new CMake templates, easier to modify code in IDE. Cons: 1. More generator branches and different code for modern desktop and Android. TODO: - [x] Add Java version check to cmake - [x] Use Cleaners for ANDROID API 33+ ### Pull Request Readiness Checklist See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request - [x] I agree to contribute to the project under Apache 2 License. - [x] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV - [ ] The PR is proposed to the proper branch - [ ] There is a reference to the original bug report and related work - [ ] There is accuracy test, performance test and test data in opencv_extra repository, if applicable Patch to opencv_extra has the same branch name. - [ ] The feature is well documented and sample code can be built with the project CMake
24 lines
693 B
Java
24 lines
693 B
Java
package org.opencv.core;
|
|
|
|
import java.lang.ref.Cleaner;
|
|
|
|
public abstract class CleanableMat {
|
|
// A native memory cleaner for the OpenCV library
|
|
public static Cleaner cleaner = Cleaner.create();
|
|
|
|
protected CleanableMat(long obj) {
|
|
if (obj == 0)
|
|
throw new UnsupportedOperationException("Native object address is NULL");
|
|
|
|
nativeObj = obj;
|
|
|
|
// The n_delete action must not refer to the object being registered. So, do not use nativeObj directly.
|
|
long nativeObjCopy = nativeObj;
|
|
cleaner.register(this, () -> n_delete(nativeObjCopy));
|
|
}
|
|
|
|
private static native void n_delete(long nativeObj);
|
|
|
|
public final long nativeObj;
|
|
}
|