From ea58523b67ad59002a1191c3c564258c5b81f6f2 Mon Sep 17 00:00:00 2001 From: liurunyu <lry9898@163.com> Date: 星期二, 06 五月 2025 17:35:16 +0800 Subject: [PATCH] Revert "1、实现万用token(0000-0000-1234-9876-5); 2、web端单独实现命令结果等待器,并修改相关部分; 3、web端实现透传命令; 4、修改一些不当注释; 5、优化一些代码。" --- pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/OnLinePool.java | 59 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 59 insertions(+), 0 deletions(-) diff --git a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/OnLinePool.java b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/OnLinePool.java new file mode 100644 index 0000000..30c764a --- /dev/null +++ b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/OnLinePool.java @@ -0,0 +1,59 @@ +package com.dy.common.mw.protocol; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; + +public class OnLinePool { + + protected static HashMap<String, List<OnLine>> pool = new HashMap<>() ; + + /** + * 鐢熸垚瀵硅薄 + * @param clazz 绫诲瀷 + * @return OnLine + */ + public static synchronized OnLine getInstance(Class<?> clazz)throws Exception { + if(pool == null){ + pool = new HashMap<>() ; + } + String className = clazz.getName() ; + OnLine obj = null ; + + List<OnLine> list = pool.get(className) ; + if(list == null){ + list = new ArrayList<>() ; + }else{ + obj = list.get(0) ; + } + + if(obj != null){ + list.remove(0) ; + return obj ; + }else{ + try { + obj = (OnLine)clazz.getDeclaredConstructor().newInstance() ; + //obj = (OnLine)clazz.newInstance(); + } catch (Exception e) { + throw new Exception( "鐢�" + className + "鐢熸垚瀹炰緥澶辫触锛�"); + } + return obj ; + } + } + + /** + * 鎶婂璞℃斁鍥炴睜涓� + * @param clazz 绫� + * @param obj 涓婄嚎瀵硅薄 + */ + public static void freeInstance(Class<?> clazz, OnLine obj){ + if(pool != null){ + String className = clazz.getName() ; + List<OnLine> list = pool.get(className) ; + if(list != null){ + list.add(obj) ; + } + } + } + +} -- Gitblit v1.8.0