什么是单例模式
单例(单个的实例)
1.所谓类的单例设计模式,就是采取一定的方法保证在整个的软件系统中,对某个类只能存在一个对象实例,并且该类只提供一个取得其对象实例的方法
2.单例模式有两种方式:饿汉式,懒汉式
步骤:
1.构造器私有化(防止直接new)
2.类的内部创建对象
3.向外暴露一个静态的公共方法*.getlnstance*
4.代码实现
饿汉式,没有使用就被创建,随着类的加载而创建
public class SingleTon01 {
public static void main(String[] args) {
Girlfriend instance = Girlfriend.getInstance();
System.out.println(instance);
}
}
//有一个类,GirlFriend
//只能有一个女朋友
class Girlfriend{
private String name;
//如何保障我们只能创建一个对象
//步骤[单例模式-饿汉式] 直接被创建好了
//1.构造器私有化
//2.在类的内部直接创建(该对象是static)
private static Girlfriend gf = new Girlfriend("小婷婷");
//通常是重量级对象,可能造成创建了没有使用
private Girlfriend(String name){
this.name = name;
}
//3.提供一个公共的static方法,返回gf对象
public static Girlfriend getInstance(){
return gf;
}
@Override
public String toString() {
return "Girlfriend{" +
"name='" + name + '\'' +
'}';
}
}
懒汉式,创建时被调用
package com.hspedu.static_.SingleTon;
/**
* 演示;懒汉式单例模式
* */
public class SingleTon02 {
public static void main(String[] args) {
Cat instance = Cat.getInstance();//只有在创建时才会被调用
System.out.println(instance.toString());
}
}
//希望在程序运行过程中,只能创建一只Cat
//使用单例模式
class Cat{
private String name;
private static Cat cat;
//1.构造器私有化
//2.定义一个static静态对象
private Cat(String name){
this.name = name;
}
//3.提供一个public的static方法,可以返回一个Cat对象
public static Cat getInstance(){
if(cat == null){
cat = new Cat("小可爱");
}
return cat;
}
@Override
public String toString() {
return "Cat{" +
"name='" + name + '\'' +
'}';
}
}
区别
1.二者最主要的区别在于创建对象的时机不同:饿汉式是在类加载就创建了对象实例,而懒汉式是在使用时才创建
2.饿汉式不存在线程安全问题,懒汉式存在线程安全问题
3.饿汉式存在浪费资源的可能,因为如果程序员一个对象实例都没有使用,那么饿汉式创建的对象酒量非了,懒汉式是使用了才创建,就不存在这个我呢提
什么是线程安全?
如果你的代码所在的进程中有多个线程在同时运行,而这些线程可能会同时运行这段代码。如果每次运行结果和单线程运行的结果是一样的,而且其他的变量的值也和预期的是一样的,就是线程安全的。
或者说:一个类或者程序所提供的接口对于线程来说是原子操作,或者多个线程之间的切换不会导致该接口的执行结果存在二义性,也就是说我们不用考虑同步的问题,那就是线程安全的。