6_2、Java基本语法之单例模式

一、设计模式的说明

        1、理解
                设计模式是在大量的实践中总结和理论化之后优的代码结构、编程风格、 以及解决问题的思考方式。可以理解为“套路”

        2 、常用设计模式
        总体来说设计模式分为大类: 
                创建型模式,共五种:工厂方法模式、抽象工厂模式、单例模式、建造者模式、原型模式。 
                结构型模式,共七种:适配器模式、装饰器模式、代理模式、外观模式、桥接模式、组合模 式、享元模式。 
                行为型模式,共十一种:策略模式、模板方法模式、观察者模式、迭代子模式、责任链模式、 命令模式、备忘录模式、状态模式、访问者模式、中介者模式、解释器模式。


二、单例模式

        1、要解决的问题:就是采取一定的方法保证在整个的软件系统中,对某个类只能存在一个对象实例。

        2、具体代码的实现(要求会手写):
                2.1、饿汉式1:

class Bank{
	
	//1.私化构造器
	private Bank(){
		
	}
	
	//2.创建一个对象
	//5.要求此对象也必须是static的
	private static Bank instance = new Bank();
	
	//3.返回单例对象的公共方法
	//4.设置为static的方法,可以使用类直接调用
	public static Bank getInstance(){
		return instance;
	}
}

public class SingletonTest1 {
	public static void main(String[] args) {
		Bank instance1 = Bank.getInstance();
		Bank instance2 = Bank.getInstance();
		
		System.out.println(instance1 == instance2);
	}
}

运行结果:比对两个实例是否指向堆空间的同一个“实体”?

                 2.2、饿汉式2:

饿汉式2:
class Order{
	
	private Order(){
		
	}
	
	public static final Order instance = new Order();

}

                        2.3、懒汉式

class Order{
	
	//1.私化类的构造器
	private Order(){
		
	}
	
	//2.创建一个未初始化的对象
	private static Order instance = null;
	
	//3.定义一个public static的返回对象的方法
	public synchronized static Order getInstance(){
		if(instance == null){
			instance = new Order();
			
		}
		return instance;
	}
	
}

        3、两种方式的对比:
                3.1、饿汉式:
                        好处:饿汉式是天然线程安全的。
                        坏处:对象的加载时间过长。
 
                3.2、懒汉式:
                        好处:延迟对象的创建。
                        

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Kotlin中,单例模式是一种非常常见的设计模式,它确保一个类只有一个实例,并提供全局访问该实例的方式。Kotlin中的单例模式可以使用对象声明来实现,这是一种非常方便的语法。但是,对象声明也有一些局限性,例如不能在运行时动态地创建对象。为了解决这个问题,可以使用带参单例模式。 带参单例模式是指在创建单例时,传递一些参数,以便在创建单例时使用。在Java中,可以使用静态方法或者静态变量来实现带参单例模式。但是在Kotlin中,可以使用伴生对象来实现带参单例模式。伴生对象是一个类的对象,可以访问该类的私有成员,并且可以实现接口。 下面是一个使用伴生对象实现带参单例模式的例子: ```kotlin class Singleton private constructor(private val name: String) { init { println("Singleton initialized with name $name") } companion object { private var instance: Singleton? = null fun getInstance(name: String): Singleton { if (instance == null) { instance = Singleton(name) } return instance!! } } } ``` 在上面的例子中,Singleton类的构造函数是私有的,只能在类内部访问。而伴生对象中的getInstance方法是公共的,可以在任何地方调用。getInstance方法接收一个name参数,用于在创建Singleton实例时使用。如果实例不存在,则创建一个新的实例,并将其存储在instance变量中。如果实例已经存在,则直接返回该实例。 可以使用以下代码创建Singleton实例: ```kotlin val singleton1 = Singleton.getInstance("test1") val singleton2 = Singleton.getInstance("test2") ``` 在上面的代码中,将分别创建名为test1和test2的两个Singleton实例。由于使用的是带参单例模式,因此可以为每个实例传递不同的参数。 带参单例模式在某些情况下非常有用,例如创建具有不同配置参数的实例。然而,需要注意的是,带参单例模式可能会导致一些问题,例如可能会导致内存泄漏或者线程安全问题。因此,在使用带参单例模式时,需要仔细考虑其适用性和安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值