java_单例设计模式

什么是设计模式

什么是单例设计模式

单例设计模式------饿汉式

虽然你没有使用这个对象实例,但是它也帮你创建了!容易造成对象的浪费

對象,通常是重量級的對象, 餓漢式可能造成創建了對象,但是沒有使用.

java 复制代码
package com.hspedu.single_;

public class SingleTon01 {
    public static void main(String[] args) {
        // GirlFriend xh = new GirlFriend("小红");
        // GirlFriend xb = new GirlFriend("小白");
        //通过方法可以获取对象
        GirlFriend instance = GirlFriend.getInstance();
        System.out.println(instance);
        GirlFriend instance2 = GirlFriend.getInstance();
        System.out.println(instance2);
        System.out.println(instance == instance2);//T
        //System.out.println(GirlFriend.n1);

    }
}

//有一个类, GirlFriend
//只能有一个女朋友
class GirlFriend {
    private String name;

    //public static int n1 = 100;
    //为了能够在静态方法中,返回 gf 对象,需要将其修饰为 static
    //對象,通常是重量級的對象, 餓漢式可能造成創建了對象,但是沒有使用.
    private static GirlFriend gf = new GirlFriend("小红红");

    //如何保障我们只能创建一个 GirlFriend 对象
    //步骤[单例模式-饿汉式]
    //1. 将构造器私有化
    //2. 在类的内部直接创建对象(该对象是 static)
    //3. 提供一个公共的 static 方法,返回 gf 对象
    private GirlFriend(String name) {
        System.out.println("構造器被調用.");
        this.name = name;
    }

    public static GirlFriend getInstance() {
        return gf;
    }

    @Override
    public String toString() {
        return "GirlFriend{" +
                "name='" + name + '\'' +
                '}';
    }
}

单例设计模式------懒汉式

java 复制代码
package com.hspedu.single_;

public class SingleTon02 {

    public static void main(String[] args) {
//new Cat("大黃");
//System.out.println(Cat.n1);
        Cat instance = Cat.getInstance();
        System.out.println(instance);
//再次調用 getInstance
        Cat instance2 = Cat.getInstance();
        System.out.println(instance2);
        System.out.println(instance == instance2);//T
    }
}
//希望在程序運行過程中,只能創建一個 Cat 對象
//使用單例模式
class Cat {
    private String name;
    public static int n1 = 999;
    private static Cat cat ; //默认是 null
    //步驟
//1.仍然构造器私有化
//2.定義一個 static 静态属性对象
//3.提供一個 public 的 static 方法,可以返回一個 Cat 對象
//4.懒汉式,只有當用戶使用 getInstance 時,才返回 cat 對象, 後面再次調用時,會返回上次創建的 cat 對象
// 从而保证了单例
    private Cat(String name) {
        System.out.println("構造器調用...");
        this.name = name;
    }
    public static Cat getInstance() {
        if(cat == null) {//如果還沒有創建 cat 對象
            cat = new Cat("小可愛");
        }
        return cat;
    }
    @Override
    public String toString() {
        return "Cat{" +
                "name='" + name + '\'' +
                '}';
    }
}

饿汉式VS懒汉式

小结:

1)单例模式的两种实现方式(1)饿汉式(2)懒汉式

2)饿汉式的问题:在类加载时候就创建,可能存在资源浪费问题

3)懒汉式的问题:线程安全问题,后面我们学了线程后,在进行完善

4)要求大家可以自己独立写出单例模式

相关推荐
せいしゅん青春之我8 分钟前
[JavaEE初阶]网络协议-状态码
java·网络协议·http
shepherd11114 分钟前
JDK源码深潜(一):从源码看透DelayQueue实现
java·后端·代码规范
天天摸鱼的java工程师22 分钟前
SpringBoot + OAuth2 + Redis + MongoDB:八年 Java 开发教你做 “安全不泄露、权限不越界” 的 SaaS 多租户平台
java·后端
东巴图23 分钟前
分解如何利用c++修复小程序的BUG
开发语言·c++·bug
鹿里噜哩23 分钟前
Nacos跨Group及Namespace发现服务
java·spring cloud
祁同伟.24 分钟前
【C++】二叉搜索树(图码详解)
开发语言·数据结构·c++·容器·stl
恒者走天下24 分钟前
AI智能网络检测项目(cpp c++项目)更新
开发语言·c++
沐浴露z34 分钟前
【JVM】详解 对象的创建
java·jvm
weixin_4454766837 分钟前
Java并发编程——提前聊一聊CompletableFuture和相关业务场景
java·并发·异步
ChinaRainbowSea38 分钟前
11. Spring AI + ELT
java·人工智能·后端·spring·ai编程