这个Employee类的构造方法中我们可以预见,如果每次需要查询一个雇员的信息。哪怕是几秒中之前刚刚查询过的,都要重新构建一个实例,这是需要消耗很多时间的。下面是一个对Employee对象进行缓存的缓存器的定义:
1. import java.lang.ref.ReferenceQueue;
2. import java.lang.ref.SoftReference;
3. import java.util.Hashtable;
4. public class EmployeeCache {
5. static private EmployeeCache cache;// 一个Cache实例
6. private Hashtable employeeRefs;// 用于Chche内容的存储
7. private ReferenceQueue q;// 垃圾Reference的队列
8.
9. // 继承SoftReference,使得每一个实例都具有可识别的标识。
10. // 并且该标识与其在HashMap内的key相同。
11. private class EmployeeRef extends SoftReference {
12. private String _key = "";
13.
14. public EmployeeRef(Employee em, ReferenceQueue q) {
15. super(em, q);
16. _key = em.getID();
17. }
18. }
19.
20. // 构建一个缓存器实例
21. private EmployeeCache() {
22. employeeRefs = new Hashtable();
23. q = new ReferenceQueue();
24. }
25.
26. // 取得缓存器实例
27. public static EmployeeCache getInstance() {
28. if (cache == null) {
29. cache = new EmployeeCache();
30. }
31. return cache;
32. }
33.
34. // 以软引用的方式对一个Employee对象的实例进行引用并保存该引用
35. private void cacheEmployee(Employee em) {
36. cleanCache();// 清除垃圾引用
37. EmployeeRef ref = new EmployeeRef(em, q);
38. employeeRefs.put(em.getID(), ref);
39. }
40.
41. // 依据所指定的ID号,重新获取相应Employee对象的实例
42. public Employee getEmployee(String ID) {
43. Employee em = null;
44. // 缓存中是否有该Employee实例的软引用,如果有,从软引用中取得。
45. if (employeeRefs.containsKey(ID)) {
46. EmployeeRef ref = (EmployeeRef) employeeRefs.get(ID);
47. em = (Employee) ref.get();
48. }
49. // 如果没有软引用,或者从软引用中得到的实例是null,重新构建一个实例,
50. // 并保存对这个新建实例的软引用
51. if (em == null) {
52. em = new Employee(ID);
53. System.out.println("Retrieve From EmployeeInfoCenter. ID=" + ID);
54. this.cacheEmployee(em);
55. }
56. return em;
57. }
58.
59. // 清除那些所软引用的Employee对象已经被回收的EmployeeRef对象
60. private void cleanCache() {
61. EmployeeRef ref = null;
62. while ((ref = (EmployeeRef) q.poll()) != null) {
63. employeeRefs.remove(ref._key);
64. }
65. }
66.
67. // 清除Cache内的全部内容
68. public void clearCache() {
69. cleanCache();
70. employeeRefs.clear();
71. System.gc();
72. System.runFinalization();
73. }
74. }
分享到:
相关推荐
Java对象的引用类型是Java内存管理中的重要概念,特别是在JDK 1.2及后续版本中引入了四种级别的引用:强引用、软引用、弱引用和虚引用,以提供更精细的控制对象生命周期的能力。 1. **强引用(StrongReference)**: ...
从JDK 1.2版本开始,Java引入了四种不同级别的引用:强引用(Strong Reference)、软引用(Soft Reference)、弱引用(Weak Reference)和虚引用(Phantom Reference)。这些引用类型提供了灵活的内存管理策略,允许...
强引用、弱引用、软引用和虚引用是四种不同的引用强度,它们在垃圾回收机制中扮演着不同的角色。了解这些引用类型对于优化内存使用、防止内存泄漏以及合理地控制对象生命周期至关重要。 1. **强引用(Strong ...
为了更好地理解和控制对象的生命周期,Java提供了四种不同类型的引用:强引用(Strong Reference)、软引用(Soft Reference)、弱引用(Weak Reference)以及虚引用(Phantom Reference)。每种引用都有其特定的...
然而,为了更好地控制内存,Java提供了不同类型的引用:强引用、弱引用、软引用和虚引用。这些引用类型允许程序员在特定场景下干预垃圾收集过程,以达到更精细的内存管理。 1. **强引用(Strong Reference)** - *...
### Java中的软引用、弱引用和虚引用详解 #### 一、引言 在Java开发过程中,特别是Android应用开发中,经常会遇到一个普遍的问题——内存溢出(OutOfMemory Error,简称OOM)。这个问题往往与如何有效地管理内存...
在JDK1.2以前的版本中,当一个对象不被任何变量引用,那么程序就无法再使用这个对象。也就是说,只有对象处于可触及状态,程序才能使用它。这 就像在日常生活中,从商店购买了某样物品后,如果有用,就一直保留它,...
从Java SE2开始,Java引入了四种不同类型的引用:强引用、软引用、弱引用和虚引用,它们各自具有不同的特点和用途,有助于程序员更精细地控制对象的生命周期,并优化垃圾回收过程。 1. 强引用(Strong Reference) ...
这个"referenceInJava"项目专注于探讨四种不同类型的引用:强引用、软引用、弱引用和虚引用。这些引用类型与垃圾收集(Garbage Collection, GC)机制密切相关,对于优化内存使用和防止内存泄漏至关重要。 1. **强...
Java对象的强、软、弱和虚引用+ReferenceQueue Java对象的强、软、弱和虚引用是Java语言中的一种机制,用于控制对象的生命周期和垃圾回收。下面是对Java对象的强、软、弱和虚引用的详细解释: 一、强引用(Strong...
在Java中,为了更好地管理对象的生命周期,从JDK 1.2开始引入了四种不同级别的引用类型:强引用、软引用、弱引用和虚引用。每种引用类型都有其特定的应用场景,通过灵活运用这些引用类型,开发者可以在内存管理和...
本文将深入探讨四种引用类型:强引用、软引用、弱引用和虚引用。 首先,我们来理解强引用(Strong Reference)。强引用是最常见的引用类型,它代表了程序中的普通对象引用。当一个对象被强引用指向时,该对象被认为...
在 Java 中,引用可以分为四类:强引用、软引用、弱引用和虚引用(也称为精灵引用)。弱引用是其中的一种,它们允许垃圾回收器在某些情况下回收对象,而不是像强引用那样坚持对象的存在。 弱引用的工作原理是,当...
从JDK1.2开始,Java引入了四种不同级别的引用,分别是强引用、软引用、弱引用和虚引用,每种引用类型都有其特定的用途和行为。 1. **强引用**:这是最常见的引用类型,如果一个对象被强引用,垃圾收集器永远不会...
Java 中强引用、软引用、弱引用概念解析 Java 中强引用、软引用、弱引用是 Java 语言...Java 中的强引用、软引用、弱引用和虚引用四种引用类型都有其特点和应用场景,选择合适的引用类型可以提高程序的性能和可读性。
强引用、弱引用、软引用和虚引用这四种引用类型提供了不同的对象生命周期管理策略。下面将详细介绍这些引用的区别及其应用场景。 1. **强引用(Strong Reference)** - 强引用是最常见的引用类型,如普通变量引用。...
- 幻象引用,也称为虚引用,是最弱的引用类型,通过`java.lang.ref.PhantomReference`实现。它不直接指向对象,甚至无法通过幻象引用访问对象。幻象引用的主要用途是在对象被finalize之后,但还没有被垃圾收集之前...
从JDK 1.2版本开始,Java引入了一种更为精细的引用类型管理机制,通过四种不同的引用类型:强引用、软引用、弱引用和虚引用,让开发者能够更加灵活地控制对象的生命周期。这种机制不仅提升了Java应用程序对内存使用...
Java中的四种引用类型是Java内存管理的重要组成部分,它们分别是强引用(StrongReference)、软引用(SoftReference)、弱引用(WeakReference)和虚引用(PhantomReference)。每种引用类型具有不同的特点和用途,...