package com.fgr.cc;
import java.util.*;
/**
* <p>Title: </p>
*
* <p>Description: 管理缓存</p>
* Deep blue 2008-11-28 think
* 可扩展的功能:当chche到内存溢出时必须清除掉最早期的一些缓存对象,这就要求对每个缓存对象保存创建时间
* <p>Copyright: Copyright (c) 2008</p>
*
* <p>Company: </p>
*
* @author Deepblue 2008-11-11
* @version 1.0
*/
public class CacheManager {
private static HashMap cacheMap = new HashMap();
//单实例构造方法
private CacheManager() {
super();
}
//获取布尔值的缓存
public static boolean getSimpleFlag(String key){
try{
return (Boolean) cacheMap.get(key);
}catch(NullPointerException e){
return false;
}
}
public static long getServerStartdt(String key){
try {
return (Long)cacheMap.get(key);
} catch (Exception ex) {
return 0;
}
}
//设置布尔值的缓存
public synchronized static boolean setSimpleFlag(String key,boolean flag){
if (flag && getSimpleFlag(key)) {//假如为真不允许被覆盖
return false;
}else{
cacheMap.put(key, flag);
return true;
}
}
public synchronized static boolean setSimpleFlag(String key,long serverbegrundt){
if (cacheMap.get(key) == null) {
cacheMap.put(key,serverbegrundt);
return true;
}else{
return false;
}
}
//得到缓存。同步静态方法
private synchronized static Cache getCache(String key) {
return (Cache) cacheMap.get(key);
}
//判断是否存在一个缓存
private synchronized static boolean hasCache(String key) {
return cacheMap.containsKey(key);
}
//清除所有缓存
public synchronized static void clearAll() {
cacheMap.clear();
}
//清除某一类特定缓存,通过遍历HASHMAP下的所有对象,来判断它的KEY与传入的TYPE是否匹配
public synchronized static void clearAll(String type) {
Iterator i = cacheMap.entrySet().iterator();
String key;
ArrayList<String> arr = new ArrayList<String>();
try {
while (i.hasNext()) {
java.util.Map.Entry entry = (java.util.Map.Entry) i.next();
key = (String) entry.getKey();
if (key.startsWith(type)) { //如果匹配则删除掉
arr.add(key);
}
}
for (int k = 0; k < arr.size(); k++) {
clearOnly(arr.get(k));
}
} catch (Exception ex) {
ex.printStackTrace();
}
}
//清除指定的缓存
public synchronized static void clearOnly(String key) {
cacheMap.remove(key);
}
//载入缓存
public synchronized static void putCache(String key, Cache obj) {
cacheMap.put(key, obj);
}
//获取缓存信息
public static Cache getCacheInfo(String key) {
if (hasCache(key)) {
Cache cache = getCache(key);
if (cacheExpired(cache)) { //调用判断是否终止方法
cache.setExpired(true);
}
return cache;
}else
return null;
}
//载入缓存信息
public static void putCacheInfo(String key, Cache obj, long dt,boolean expired) {
Cache cache = new Cache();
cache.setKey(key);
cache.setTimeOut(dt + System.currentTimeMillis()); //设置多久后更新缓存
cache.setValue(obj);
cache.setExpired(expired); //缓存默认载入时,终止状态为FALSE
cacheMap.put(key, cache);
}
//重写载入缓存信息方法
public static void putCacheInfo(String key,Cache obj,long dt){
Cache cache = new Cache();
cache.setKey(key);
cache.setTimeOut(dt+System.currentTimeMillis());
cache.setValue(obj);
cache.setExpired(false);
cacheMap.put(key,cache);
}
//判断缓存是否终止
public static boolean cacheExpired(Cache cache) {
if (null == cache) { //传入的缓存不存在
return false;
}
long nowDt = System.currentTimeMillis(); //系统当前的毫秒数
long cacheDt = cache.getTimeOut(); //缓存内的过期毫秒数
if (cacheDt <= 0||cacheDt>nowDt) { //过期时间小于等于零时,或者过期时间大于当前时间时,则为FALSE
return false;
} else { //大于过期时间 即过期
return true;
}
}
//获取缓存中的大小
public static int getCacheSize() {
return cacheMap.size();
}
//获取指定的类型的大小
public static int getCacheSize(String type) {
int k = 0;
Iterator i = cacheMap.entrySet().iterator();
String key;
try {
while (i.hasNext()) {
java.util.Map.Entry entry = (java.util.Map.Entry) i.next();
key = (String) entry.getKey();
if (key.indexOf(type) != -1) { //如果匹配则删除掉
k++;
}
}
} catch (Exception ex) {
ex.printStackTrace();
}
return k;
}
//获取缓存对象中的所有键值名称
public static ArrayList<String> getCacheAllkey() {
ArrayList a = new ArrayList();
try {
Iterator i = cacheMap.entrySet().iterator();
while (i.hasNext()) {
java.util.Map.Entry entry = (java.util.Map.Entry) i.next();
a.add((String) entry.getKey());
}
} catch (Exception ex) {} finally {
return a;
}
}
//获取缓存对象中指定类型 的键值名称
public static ArrayList<String> getCacheListkey(String type) {
ArrayList a = new ArrayList();
String key;
try {
Iterator i = cacheMap.entrySet().iterator();
while (i.hasNext()) {
java.util.Map.Entry entry = (java.util.Map.Entry) i.next();
key = (String) entry.getKey();
if (key.indexOf(type) != -1) {
a.add(key);
}
}
} catch (Exception ex) {} finally {
return a;
}
}
}
java国际化代码(jsp)


Java国际化(i18n,Internationalization)是Java平台提供的一种强大的功能,使得软件能够适应不同语言和文化环境。在Java中,国际化主要通过资源包(Resource Bundle)和Locale对象来实现。资源包是一个包含特定语言环境信息的集合,如字符串、图像或其他本地化资源。Locale对象则用于表示特定的语言和地区。 1. **Java资源包**: 资源包通常是`.properties`格式的文本文件,其中包含了键值对,键是不变的标识符,值是根据语言环境变化的文本。例如,一个英语版本的资源包可能包含`greeting=Hello`,而法语版本的资源包则可能是`greeting=Bonjour`。资源包通常以`messages.properties`作为基础文件,然后针对不同的语言创建对应的`messages_fr.properties`(法语)或`messages_de.properties`(德语)等。 2. **Locale对象**: `java.util.Locale`类是Java中的核心类,用于定义语言、国家和地区。例如,`Locale("en", "US")`代表英语(美国),`Locale("fr", "FR")`代表法语(法国)。程序可以根据用户的选择或系统设置创建合适的Locale对象,并根据此对象加载相应的资源包。 3. **使用ResourceBundle**: `java.util.ResourceBundle`类用于加载和管理资源包。在JSP中,可以通过`ResourceBundle.getBundle()`方法获取对应的资源包,传入的参数是资源包的基名(通常是不带后缀的文件名)和Locale对象。例如: ```java ResourceBundle bundle = ResourceBundle.getBundle("messages", new Locale("fr", "FR")); String greeting = bundle.getString("greeting"); ``` 这段代码将加载法语的资源包,并获取`greeting`键对应的值。 4. **缓存技术**: 为了提高性能,可以使用Java的缓存机制来存储已经加载过的资源包,避免频繁的磁盘I/O操作。例如,可以使用`ConcurrentHashMap`来存储已加载的资源包,键是Locale对象,值是对应的ResourceBundle实例。当需要加载新的资源包时,首先检查缓存中是否存在,如果存在则直接返回,否则再从磁盘加载。 5. **JSP中的应用**: 在JSP页面中,可以直接将获取到的本地化字符串插入到HTML中,或者通过EL表达式(Expression Language)和JSTL(JavaServer Pages Standard Tag Library)标签库来展示。例如: ```jsp <jsp:useBean id="bundle" class="java.util.ResourceBundle" scope="session"> <jsp:setProperty name="bundle" property="basename" value="messages"/> </jsp:useBean> <fmt:setLocale value="${sessionScope.locale}"/> <fmt:message key="greeting"/> ``` 这段JSP代码会根据session中的locale设置,加载相应的资源包,并显示`greeting`键的值。 6. **国际化最佳实践**: - 保持资源包的结构清晰,按功能或模块组织。 - 避免在资源包中包含硬编码的日期、数字或货币格式,应使用`java.text.SimpleDateFormat`和`java.text.NumberFormat`进行格式化。 - 使用工具如`java.text.MessageFormat`来处理包含变量的本地化字符串。 - 对于复杂的本地化需求,可以考虑使用Java的`java.time`包和`java.text.DecimalFormatSymbols`。 7. **扩展性**: Java国际化不仅限于字符串,还可以本地化日期、时间、数字格式,甚至整个用户界面布局。通过组合使用Java的这些特性,可以构建高度可扩展且适应多种语言环境的应用程序。 Java的国际化功能强大且灵活,通过正确使用资源包、Locale和缓存技术,开发者可以轻松地构建支持多语言的Web应用。在实际开发中,理解并熟练掌握这些知识点对于提升用户体验至关重要。




































































- 1

- #完美解决问题
- #运行顺畅
- #内容详尽
- #全网独家
- #注释完整

- 粉丝: 5
- 资源: 4
我的内容管理 展开
我的资源 快来上传第一个资源
我的收益
登录查看自己的收益我的积分 登录查看自己的积分
我的C币 登录后查看C币余额
我的收藏
我的下载
下载帮助


最新资源
- 西门子S7-1200 PLC自定义堆栈程序的SCL实现与应用
- 基于springboot框架的图书管理系统(完整Java源码+数据库sql文件+项目文档+Java项目编程实战+编程练手好项目).zip
- 基于STC89C52单片机的电流电压采集系统:硬件设计与C语言实现
- 配电网重构技术:正常重构、孤岛划分及故障重构的Python实现与应用
- 基于STM32F407和UCOS2的HLW8032三相电参数采集系统设计与实现
- C# Socket通信模块:适用于物联网项目的高效连接管理和数据处理
- YOLO目标检测数据集,轴承外观缺陷检测数据集,1000多张标注好的数据集,开箱即用
- MATLAB实现遗传算法解决容量受限车辆路径(CVRP)问题
- EPSON机械手与相机及PLC基于TCP/IP协议的自动化控制系统集成
- 基于SpringBoot框架的装饰工程管理系统(完整Java源码+数据库sql文件+项目文档+Java项目编程实战+编程练手好项目).zip
- 信捷PLC与台达伺服A2/B2实现高效拧螺丝系统的硬件连接、参数配置及PLC编程
- PLC水处理系统:基于昆仑通态触摸屏与LS XGB系列PLC的应用实例解析
- 基于Matlab的整车动力系统匹配计算:参数输入与性能需求自动化评估
- C++编程面试必备:30道经典常考题目详解及应用场景
- 汽车电子UDS刷写系统:基于CAPL脚本与Panel界面的全流程实现
- 大语言模型(THE CHINESE BOOK FOR LARGE LANGUAGE MODELS)


