From 1a2b07f01ba4616fd9e894dddf474b56d020158c Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期一, 07 四月 2025 15:18:51 +0800
Subject: [PATCH] 整理版本

---
 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