From 33af27ee7a189b538452fc9adb63e0784324e009 Mon Sep 17 00:00:00 2001 From: liurunyu <lry9898@163.com> Date: 星期三, 24 七月 2024 10:49:37 +0800 Subject: [PATCH] Merge branch 'master' of http://8.140.179.55:20000/r/pipIrr-SV --- pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/ProtocolCache.java | 91 +++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 91 insertions(+), 0 deletions(-) diff --git a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/ProtocolCache.java b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/ProtocolCache.java new file mode 100644 index 0000000..c076537 --- /dev/null +++ b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/ProtocolCache.java @@ -0,0 +1,91 @@ +package com.dy.common.mw.protocol; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +public class ProtocolCache { + + //鏈郴缁熶腑锛孌river鍦ㄥ崟绾跨▼涓繍琛岋紝鎵�浠ュ彧鐢ㄤ竴涓疄渚� + private static final HashMap<String, Driver> drivers = new HashMap<>() ; + //娉ㄨВ涓庡鐞嗙被鐨勬槧灏� + private static final HashMap<String, AnnotationDriverVo> driverMap = new HashMap<>() ; + private static final HashMap<String, AnnotationPrefixedDataAvailableVo> prefixedDataAvailableMap = new HashMap<>() ; + private static final HashMap<String, AnnotationOnLineVo> onLineMap = new HashMap<>() ; + + + /** + * 鍦ㄥ崟绾跨▼鐜涓繍琛� + * 閫氳繃鍗忚椹卞姩鐨勭被鍚嶏紝寰楀埌绫诲崟渚� + * @param protocolName 鍗忚鍚嶇О + * @return 椹卞姩 + * @throws Exception 寮傚父 + */ + public static Driver getDriver(String protocolName) throws Exception{ + Driver dri = drivers.get(protocolName); + if(dri == null){ + AnnotationDriverVo vo = driverMap.get(protocolName) ; + if(vo != null && vo.clazz != null){ + dri = (Driver)vo.clazz.getDeclaredConstructor().newInstance(); + //dri = (Driver)vo.clazz.newInstance() ; + drivers.put(protocolName, dri) ; + } + } + return dri ; + } + + /** + * 寰楀埌椹卞姩鐨勬暟閲忥紝鍗充腑闂翠欢鏀寔鐨勫崗璁暟閲� + * @return 椹卞姩鎬绘暟 + */ + public static int driverCount(){ + if(drivers.size() == 0){ + return 0 ; + }else{ + return drivers.size() ; + } + } + + /** + * 寰楀埌绗竴涓┍鍔� + * @return 椹卞姩 + */ + public static Driver getFirstDriver(){ + Driver dri = null ; + if(drivers.size() > 0){ + Map.Entry<String, Driver> ent = drivers.entrySet().iterator().next() ; + dri = ent.getValue(); + } + return dri ; + } + + /** + * 寰楀埌鎵�鏈夊崗璁悕绉� + * @return 鍗忚鍚嶇О闆嗗悎 + */ + @SuppressWarnings("unused") + public static List<String> getProtocolList() { + return new ArrayList<>(driverMap.keySet()) ; + } + + protected static HashMap<String, AnnotationDriverVo> getDriverMap() { + return driverMap; + } + protected static HashMap<String, AnnotationPrefixedDataAvailableVo> getPrefixedDataAvailableMap() { + return prefixedDataAvailableMap; + } + protected static HashMap<String, AnnotationOnLineVo> getOnLineMap() { + return onLineMap; + } + + /* + public static void main(String[] args){ + HashMap<String, Integer> mp = new HashMap<>() ; + mp.put("a1", 1) ; + mp.put("a2", 2) ; + List<String> list = new ArrayList<>(mp.keySet()) ; + System.out.println(list); + } + */ +} \ No newline at end of file -- Gitblit v1.8.0