详略。。设计模式2——单例变形(多例).。。。studying

本文探讨了在编程中如何结合缓存技术与单例模式,通过实例展示了如何实现缓存单例对象,并进一步扩展为控制实例个数的对象池。详细介绍了Java代码实现及其实现原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

★ 缓存在单例中的使用(“单例+缓存”技术)

缓存在编程中使用很频繁,有着非常重要的作用,它能够帮助程序实现以空间换取时间,

通常被设计成整个应用程序所共享的一个空间,现要求实现一个用缓存存放单例对象的类。
说明:该缓存中可以存放多个该类对象,每个对象以一个key值标识,key值相同时所访问的是同一个单例对象。

★ 单例变形——多例模式(“单例+缓存+控制实例个数”技术)

把上面缓存的单例实现,做成一个能够控制对象个数的共享空间,供整个应用程序使用。

在缓存中维护指定个数的对象,每个对象的key值由该类内部指定,有外部请求时直接返回其中一个对象出去。
说明:相当于维护一个指定数量的对象池,当请求个数超过控制的总数时,开始循环重复使用 。


java代码实现:

package cn.hncu.patterns.exercise.mutiple;

import java.util.HashMap;

public class Mutiple {
	/*
	 * hm哈希集合,本例用作缓存
	 * number指定实例个数为3
	 * count游标
	 */
	private static HashMap<Integer, Mutiple> hm = new HashMap<Integer, Mutiple>();
	private static final int NUMBER = 3;
	private static int count = 0;

	private Mutiple() {
	}

	/*
	 * 在缓存中维护指定个数的对象,
	 * 每个对象的key值由该类内部指定,
	 * 有外部请求时直接返回其中一个对象出去。
	 */
	public static Mutiple getInstance() {
		Mutiple m = hm.get(count);
		if (m == null) {
			m = new Mutiple();
			hm.put(count, m);
		}
		count++;
		if (count >= NUMBER) {
			count = 0;
		}
		return m;
	}

	/*
	 * 测试代码
	 */
	public static void main(String[] args) {
		System.out.println(Mutiple.getInstance());
		System.out.println(Mutiple.getInstance());
		System.out.println(Mutiple.getInstance());
		System.out.println(Mutiple.getInstance());
		System.out.println(Mutiple.getInstance());
	}

}

测试结果






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值