Java 教程
- Java - 首页
- Java - 概述
- Java - 历史
- Java - 特性
- Java vs. C++
- JVM - Java虚拟机
- Java - JDK vs JRE vs JVM
- Java - Hello World 程序
- Java - 环境搭建
- Java - 基本语法
- Java - 变量类型
- Java - 数据类型
- Java - 类型转换
- Java - Unicode系统
- Java - 基本运算符
- Java - 注释
- Java - 用户输入
- Java - 日期与时间
Java 控制语句
- Java - 循环控制
- Java - 决策制定
- Java - if-else
- Java - switch
- Java - for循环
- Java - for-each循环
- Java - while循环
- Java - do-while循环
- Java - break
- Java - continue
面向对象编程
- Java - OOPs概念
- Java - 对象与类
- Java - 类属性
- Java - 类方法
- Java - 方法
- Java - 变量作用域
- Java - 构造函数
- Java - 访问修饰符
- Java - 继承
- Java - 聚合
- Java - 多态
- Java - 重写
- Java - 方法重载
- Java - 动态绑定
- Java - 静态绑定
- Java - 实例初始化块
- Java - 抽象
- Java - 封装
- Java - 接口
- Java - 包
- Java - 内部类
- Java - 静态类
- Java - 匿名类
- Java - 单例类
- Java - 包装类
- Java - 枚举
- Java - 枚举构造函数
- Java - 枚举字符串
Java 内置类
Java 文件处理
Java 错误与异常
- Java - 异常
- Java - try-catch块
- Java - try-with-resources
- Java - 多重catch块
- Java - 嵌套try块
- Java - finally块
- Java - throw异常
- Java - 异常传播
- Java - 内置异常
- Java - 自定义异常
Java 多线程
- Java - 多线程
- Java - 线程生命周期
- Java - 创建线程
- Java - 启动线程
- Java - 线程连接
- Java - 线程命名
- Java - 线程调度器
- Java - 线程池
- Java - 主线程
- Java - 线程优先级
- Java - 守护线程
- Java - 线程组
- Java - 关闭钩子
Java 同步
Java 网络编程
- Java - 网络编程
- Java - 套接字编程
- Java - URL处理
- Java - URL类
- Java - URLConnection类
- Java - HttpURLConnection类
- Java - Socket类
- Java - 泛型
Java 集合
Java 接口
Java 数据结构
Java 集合算法
高级Java
- Java - 命令行参数
- Java - Lambda表达式
- Java - 发送邮件
- Java - Applet基础
- Java - Javadoc注释
- Java - 自动装箱和拆箱
- Java - 文件不匹配方法
- Java - REPL (JShell)
- Java - 多版本Jar文件
- Java - 私有接口方法
- Java - 内部类菱形运算符
- Java - 多分辨率图像API
- Java - 集合工厂方法
- Java - 模块系统
- Java - Nashorn JavaScript
- Java - Optional类
- Java - 方法引用
- Java - 函数式接口
- Java - 默认方法
- Java - Base64编码解码
- Java - switch表达式
- Java - Teeing Collectors
- Java - 微基准测试
- Java - 文本块
- Java - 动态CDS存档
- Java - Z垃圾收集器(ZGC)
- Java - 空指针异常
- Java - 打包工具
- Java - 密封类
- Java - 记录类
- Java - 隐藏类
- Java - 模式匹配
- Java - 简洁的数字格式化
- Java - 垃圾收集
- Java - JIT编译器
Java 杂项
- Java - 递归
- Java - 正则表达式
- Java - 序列化
- Java - 字符串
- Java - Process API改进
- Java - Stream API改进
- Java - 增强@Deprecated注解
- Java - CompletableFuture API改进
- Java - 流
- Java - 日期时间API
- Java 8 - 新特性
- Java 9 - 新特性
- Java 10 - 新特性
- Java 11 - 新特性
- Java 12 - 新特性
- Java 13 - 新特性
- Java 14 - 新特性
- Java 15 - 新特性
- Java 16 - 新特性
Java APIs与框架
Java 类引用
- Java - Scanner
- Java - 数组
- Java - 字符串
- Java - Date
- Java - ArrayList
- Java - Vector
- Java - Stack
- Java - PriorityQueue
- Java - LinkedList
- Java - ArrayDeque
- Java - HashMap
- Java - LinkedHashMap
- Java - WeakHashMap
- Java - EnumMap
- Java - TreeMap
- Java - IdentityHashMap
- Java - HashSet
- Java - EnumSet
- Java - LinkedHashSet
- Java - TreeSet
- Java - BitSet
- Java - Dictionary
- Java - Hashtable
- Java - Properties
- Java - Collection
- Java - Array
Java 有用资源
Java - 单例类
Java单例设计模式
单例模式是Java中最简单的设计模式之一。这种设计模式属于创建模式,因为它提供了一种创建对象的最佳方法。
Java单例类
这种模式涉及一个单一的类,它负责创建对象,同时确保只创建单个对象。这个类提供了一种访问其唯一对象的方法,可以直接访问而无需实例化类的对象。
由于只有一个单例实例,单例的任何实例字段都只会在每个类中出现一次,就像静态字段一样。单例通常控制对资源的访问,例如数据库连接或套接字。
例如,如果您只有一个数据库连接许可证,或者您的JDBC驱动程序在多线程方面存在问题,则单例确保只建立一个连接,或者只有一个线程可以同时访问连接。
单例设计模式的优点
单例设计模式节省内存,因为它只创建了一个对象实例,并且它还提供对其实例的全局访问。
单例设计模式的用途
当您想要创建一个只有一个实例的类时,使用单例设计模式。它主要用于多线程中,以创建多线程和数据库相关的应用程序。
一些使用单例设计模式的设计
- 创建日志记录类
- 创建与配置管理相关的类
- 创建与数据库连接池相关的类
- 为缓存机制创建一个类
Java单例类/设计模式:示例
示例1
最简单的实现包括一个私有构造函数和一个用于保存其结果的字段,以及一个具有诸如getInstance()之类的名称的静态访问器方法。
私有字段可以在静态初始化块中赋值,或者更简单地使用初始化器赋值。getInstance()方法(必须是公共的)然后简单地返回此实例 -
package com.tutorialspoint; class Singleton { private static Singleton singleton = new Singleton( ); /* A private Constructor prevents any other * class from instantiating. */ private Singleton() { } /* Static 'instance' method */ public static Singleton getInstance( ) { return singleton; } /* Other methods protected by singleton-ness */ protected void demoMethod( ) { System.out.println("demoMethod for singleton"); } } public class Tester { public static void main(String[] args) { Singleton tmp = Singleton.getInstance( ); tmp.demoMethod( ); } }
如果您编译并执行上述程序,您将得到以下结果 -
输出
demoMethod for singleton
示例2
下面的实现显示了一个经典的单例设计模式。在这个例子中,ClassicSingleton类维护对唯一单例实例的静态引用,并从静态getInstance()方法返回该引用。
在这里,ClassicSingleton类采用了一种称为延迟实例化的技术来创建单例;因此,只有在第一次调用getInstance()方法时才会创建单例实例。这种技术确保仅在需要时才创建单例实例。
package com.tutorialspoint; class ClassicSingleton { private static ClassicSingleton instance = null; private ClassicSingleton() { // Exists only to defeat instantiation. } public static ClassicSingleton getInstance() { if(instance == null) { instance = new ClassicSingleton(); } return instance; } protected void demoMethod( ) { System.out.println("demoMethod for singleton"); } } public class Tester { public static void main(String[] args) { ClassicSingleton tmp = ClassicSingleton.getInstance( ); tmp.demoMethod( ); } }
如果您编译并执行上述程序,您将得到以下结果 -
输出
demoMethod for singleton
示例3
下面的实现显示了一个线程安全的单例对象创建。在这个例子中,ClassicSingleton类维护对唯一单例实例的静态引用,并从静态getInstance()方法返回该引用,我们使用synchronized关键字使其成为线程安全的。
class ClassicSingleton { private static ClassicSingleton instance = null; private ClassicSingleton() { // Exists only to defeat instantiation. } public static synchronized ClassicSingleton getInstance() { if(instance == null) { instance = new ClassicSingleton(); } return instance; } protected void demoMethod( ) { System.out.println("demoMethod for singleton"); } } public class Tester { public static void main(String[] args) { ClassicSingleton tmp = ClassicSingleton.getInstance( ); tmp.demoMethod( ); } }
如果您编译并执行上述程序,您将得到以下结果 -
输出
demoMethod for singleton