From 3903c6f4ef7f5fa7dd931bbffc51d0ce0d6f0af1 Mon Sep 17 00:00:00 2001 From: 潘志宝 <979469083@qq.com> Date: 星期三, 08 一月 2025 17:40:07 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- iailab-module-model/iailab-module-model-biz/src/main/resources/template/cpp.vm | 52 ++++++++++++++++++++++------------------------------ 1 files changed, 22 insertions(+), 30 deletions(-) diff --git a/iailab-module-model/iailab-module-model-biz/src/main/resources/template/cpp.vm b/iailab-module-model/iailab-module-model-biz/src/main/resources/template/cpp.vm index 939e6ba..b4ddf01 100644 --- a/iailab-module-model/iailab-module-model-biz/src/main/resources/template/cpp.vm +++ b/iailab-module-model/iailab-module-model-biz/src/main/resources/template/cpp.vm @@ -17,7 +17,21 @@ { PyGILThreadLock lock; - PyObject* pModule = create_py_module("${pyModule}.${pyName}"); + + jclass hashmapClass = env->FindClass("java/util/HashMap"); + jmethodID getMID = env->GetMethodID(hashmapClass, "get", "(Ljava/lang/Object;)Ljava/lang/Object;"); + jstring keyJString = env->NewStringUTF("pyFile"); + jobject javaValueObj = env->CallObjectMethod(settings, getMID, keyJString); + jstring javaStringValue = (jstring)javaValueObj; + const char* strValue = env->GetStringUTFChars(javaStringValue, NULL); + //*************导入模型****************** + PyObject* pModule = create_py_module(strValue); + // 释放java占用内存 + env->ReleaseStringUTFChars(javaStringValue, strValue); + env->DeleteLocalRef(javaStringValue); + env->DeleteLocalRef(javaValueObj); + env->DeleteLocalRef(keyJString); + env->DeleteLocalRef(hashmapClass); if (pModule == NULL) { cout << "model error" << endl; @@ -80,39 +94,17 @@ cout << "ConvertPydictToJhmap error" << endl; throw "函数返回值异常!"; } - /*delete pModule; - pModule = nullptr; - delete pModule; - - delete pFunc; - pFunc = nullptr; - delete pFunc; - + cout << "clear_py_memory" << endl; + Py_XDECREF(pFunc); #{foreach} ($column in [1..$entity.dataLength]) - delete[] data_${column}; - data_${column} = nullptr; - delete data_${column}; - + Py_XDECREF(data_${column}); #{end} #{if}($entity.model==1) - delete model_path; - model_path = nullptr; - delete model_path; + Py_XDECREF(model_path); #{end} - - delete settings_1; - settings_1 = nullptr; - delete settings_1; - - delete[] pArg; - pArg = nullptr; - delete pArg; - - Py_DECREF(pReturn); - Py_DECREF(pFunc); - Py_DECREF(pModule); - Py_CLEAR(pModule);*/ - + Py_XDECREF(settings_1); + Py_XDECREF(pArg); + Py_XDECREF(pReturn); return result; } catch (const char* msg) -- Gitblit v1.9.3