博客
关于我
单例对象和多例对象
阅读量:762 次
发布时间:2019-03-23

本文共 1381 字,大约阅读时间需要 4 分钟。

单例对象和多例对象

在软件开发中,单例对象和多例对象是非常常见的设计模式,它们在不同的场景下发挥着重要作用。本文将详细介绍这两种模式的特点、优缺点以及它们的应用场景。

首先,我们来了解什么是单例对象。单例对象指的是在程序运行的整个生命周期中,始终只存在一个对象来处理所有相关请求。这种模式非常适合资源有限的环境,因为它可以减少内存占用和对象的频繁创建带来的开销。

接下来,我们探讨单例对象的实现方式。单例模式分为两种主要实现方式:懒汉模式和饿汉模式。

  • 懒汉模式:这个模式的特点是对象的创建尽量被推迟,也就是说,只有在首次访问时,才会创建对象。这种方式可以节省内存,并避免在应用启动时就创建对象可能带来的性能问题。例如,下面是一个典型的懒汉单例实现代码:
  • class Singleton01 {    private static Singleton01 modle; // 声明对象    private Singleton01() { // 使构造函数私有化  }    public static Singleton01 getInstance() {        if (modle == null) {            modle = new Singleton01();        }        return modle;    }}
    1. 饿汉模式:这种方式完全沿用单例的概念,但对象的创建却更加早,即在类加载时就进行创建。这种方式的优势在于可以保证对象一定存在,不会有空的单例对象带来的问题,但它也存在一个缺点:当类没有被使用时,可能会占用内存资源。例如,一个典型的饿汉单例实现如下:
    2. class Singleton02 {    private static Singleton02 modle = new Singleton02(); // 一旦加载就创建对象    private Singleton02() { // 使构造函数私有化  }    public static Singleton02 getInstance() {        return modle;    }}

      接下来我们来比较单例对象和多例对象的优缺点。

      单例对象的优势显而易见,它创建的对象最少,资源利用效率高。它能有效降低内存占用,并减少垃圾回收带来的开销。然而,它也有一个潜在的缺点:在多线程环境下,饿汉模式可能会出现线索安全问题,因为当多个线程同时访问时,可能会导致对象被多次创建。

      而多例对象则有截然不同的特点。它允许多个对象对象同时存在,每个请求都可以拥有一个独立的对象实例。这种方式虽然资源消耗较大,但却避免了线程竞争带来的潜在问题。

      在实际应用中,这两种模式各有其适用场景。广泛应用的三层架构服务层和持久层通常会使用单例模式。例如,Spring的Bean默认是单例模式,SpringMVC的各个组件也是如此。对于需要根据用户信息或其他动态条件创建不同的逻辑组件的场景,多例模式才是更合适的选择。例如,Struts框架的Action类就是典型的多例模式,因为每个用户都有自己独立的会话和数据。

      总的来说,选择单例还是多例模式,应根据具体的应用需求和场景来决定。无论是单例还是多例模式,在合理使用的情况下,都能够为程序的性能和稳定性做出贡献。

    转载地址:http://duizk.baihongyu.com/

    你可能感兴趣的文章
    mysql 默认事务隔离级别下锁分析
    查看>>
    Mysql--逻辑架构
    查看>>
    MySql-2019-4-21-复习
    查看>>
    mysql-5.6.17-win32免安装版配置
    查看>>
    mysql-5.7.18安装
    查看>>
    MySQL-Buffer的应用
    查看>>
    mysql-cluster 安装篇(1)---简介
    查看>>
    mysql-connector-java.jar乱码,最新版mysql-connector-java-8.0.15.jar,如何愉快的进行JDBC操作...
    查看>>
    mysql-connector-java各种版本下载地址
    查看>>
    mysql-EXPLAIN
    查看>>
    MySQL-Explain的详解
    查看>>
    mysql-group_concat
    查看>>
    MySQL-redo日志
    查看>>
    MySQL-【1】配置
    查看>>
    MySQL-【4】基本操作
    查看>>
    Mysql-丢失更新
    查看>>
    Mysql-事务阻塞
    查看>>
    Mysql-存储引擎
    查看>>
    mysql-开启慢查询&所有操作记录日志
    查看>>
    MySQL-数据目录
    查看>>