博客
关于我
单例对象和多例对象
阅读量: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 主从 lock_mysql 主从同步权限mysql 行锁的实现
    查看>>
    mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
    查看>>
    mysql 主从关系切换
    查看>>
    MYSQL 主从同步文档的大坑
    查看>>
    mysql 主键重复则覆盖_数据库主键不能重复
    查看>>
    Mysql 事务知识点与优化建议
    查看>>
    Mysql 优化 or
    查看>>
    mysql 优化器 key_mysql – 选择*和查询优化器
    查看>>
    MySQL 优化:Explain 执行计划详解
    查看>>
    Mysql 会导致锁表的语法
    查看>>
    mysql 使用sql文件恢复数据库
    查看>>
    mysql 修改默认字符集为utf8
    查看>>
    Mysql 共享锁
    查看>>
    MySQL 内核深度优化
    查看>>
    mysql 内连接、自然连接、外连接的区别
    查看>>
    mysql 写入慢优化
    查看>>
    mysql 分组统计SQL语句
    查看>>
    Mysql 分页
    查看>>