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