From c9e48bd2dff2b5766589024cf7264189b5f2a05c Mon Sep 17 00:00:00 2001 From: dengzedong <dengzedong@email> Date: 星期五, 03 一月 2025 14:03:33 +0800 Subject: [PATCH] cpp释放java占用内存 --- iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mcs/pre/service/impl/MmModelArithSettingsServiceImpl.java | 39 +++++++++++++++++++++++---------------- 1 files changed, 23 insertions(+), 16 deletions(-) diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mcs/pre/service/impl/MmModelArithSettingsServiceImpl.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mcs/pre/service/impl/MmModelArithSettingsServiceImpl.java index cf92cf3..dc13a83 100644 --- a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mcs/pre/service/impl/MmModelArithSettingsServiceImpl.java +++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mcs/pre/service/impl/MmModelArithSettingsServiceImpl.java @@ -1,10 +1,7 @@ package com.iailab.module.model.mcs.pre.service.impl; -import com.baomidou.dynamic.datasource.annotation.DSTransactional; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; -import com.iailab.framework.common.service.impl.BaseServiceImpl; -import com.iailab.module.model.mcs.pre.dao.MmItemTypeDao; import com.iailab.module.model.mcs.pre.dao.MmModelArithSettingsDao; import com.iailab.module.model.mcs.pre.entity.MmModelArithSettingsEntity; import com.iailab.module.model.mcs.pre.service.MmModelArithSettingsService; @@ -13,6 +10,7 @@ import org.springframework.util.CollectionUtils; import java.util.*; +import java.util.concurrent.ConcurrentHashMap; /** * @author PanZhibao @@ -25,6 +23,8 @@ @Autowired private MmModelArithSettingsDao mmModelArithSettingsDao; + private static Map<String, List<MmModelArithSettingsEntity>> modelIdMap = new ConcurrentHashMap<>(); + @Override public void saveList(List<MmModelArithSettingsEntity> list) { QueryWrapper<MmModelArithSettingsEntity> queryWrapper = new QueryWrapper(); @@ -34,23 +34,30 @@ item.setId(UUID.randomUUID().toString()); }); mmModelArithSettingsDao.insertList(list); - } - public List<MmModelArithSettingsEntity> getByModelid(String modelid) { - Map<String, Object> params = new HashMap<>(1); - params.put("modelid", modelid); - List<MmModelArithSettingsEntity> list = mmModelArithSettingsDao.getMmModelArithSettings(params); - - if (CollectionUtils.isEmpty(list)) { - return new ArrayList<>(); - } - return list; + // 清空缓存 + modelIdMap.clear(); } @Override public List<MmModelArithSettingsEntity> getByModelId(String modelId) { - QueryWrapper<MmModelArithSettingsEntity> queryWrapper = new QueryWrapper(); - queryWrapper.eq("modelid", modelId); - return mmModelArithSettingsDao.selectList(queryWrapper); + if (modelIdMap.containsKey(modelId)) { + return modelIdMap.get(modelId); + } + Map<String, Object> params = new HashMap<>(1); + params.put("modelid", modelId); + List<MmModelArithSettingsEntity> list = mmModelArithSettingsDao.getMmModelArithSettings(params); + if (CollectionUtils.isEmpty(list)) { + list = new ArrayList<>(); + } + modelIdMap.put(modelId, list); + return list; + } + + @Override + public void updatePyFile(String pyModule, String fileName) { + baseMapper.updatePyFile(pyModule + "." + fileName.substring(0,fileName.lastIndexOf("_")+1),pyModule + "." + fileName); + // 清空缓存 + modelIdMap.clear(); } } -- Gitblit v1.9.3