用java写一个线程安全的单例饿汉模式
时间: 2023-05-28 20:05:56 浏览: 50
public class Singleton {
private static final Singleton INSTANCE = new Singleton();
private Singleton() {
}
public static Singleton getInstance() {
return INSTANCE;
}
}
// 使用 synchronized 关键字实现线程安全的单例饿汉模式
public class Singleton {
private static Singleton INSTANCE;
private Singleton() {
}
public static synchronized Singleton getInstance() {
if (INSTANCE == null) {
INSTANCE = new Singleton();
}
return INSTANCE;
}
}
相关问题
使用Java写一个单例模式
单例模式是一种常见的设计模式,它确保一个类只能创建一个对象,并提供对该对象的全局访问点。在Java中,实现单例模式可以采用以下方式:
1. 饿汉式单例模式
```java
public class Singleton {
// 创建一个Singleton对象,使用private static final修饰,确保只有一个实例
private static final Singleton instance = new Singleton();
// 构造函数私有化,禁止外部实例化对象
private Singleton() {}
// 提供静态方法返回Singleton实例
public static Singleton getInstance() {
return instance;
}
}
```
2. 懒汉式单例模式
```java
public class Singleton {
// 创建一个Singleton对象,但不进行初始化
private static Singleton instance;
// 构造函数私有化,禁止外部实例化对象
private Singleton() {}
// 提供静态方法返回Singleton实例,当instance为null时进行初始化
public static Singleton getInstance() {
if (instance == null) {
instance = new Singleton();
}
return instance;
}
}
```
以上两种方式都是线程安全的。如果需要保证线程安全,可以将getInstance()方法加上synchronized关键字。
3. 双重校验锁单例模式
```java
public class Singleton {
// 创建一个volatile修饰的Singleton对象,确保线程可见性
private static volatile Singleton instance;
// 构造函数私有化,禁止外部实例化对象
private Singleton() {}
// 提供静态方法返回Singleton实例,使用双重校验锁确保线程安全
public static Singleton getInstance() {
if (instance == null) {
synchronized (Singleton.class) {
if (instance == null) {
instance = new Singleton();
}
}
}
return instance;
}
}
```
以上三种方式都可以实现单例模式,选择哪一种方式取决于实际需要。
java 确保线程安全的单例模式
1. 饿汉式——线程安全的单例模式
这是一种最简单的实现方式。在类加载的时候就创建了实例,因此保证了线程安全。缺点是无论是否需要这个对象,都会在程序启动时被加载,从而浪费了一定的空间。
```java
public class Singleton {
//创建 Singleton 的一个对象
private static Singleton instance = new Singleton();
//让构造函数为 private,这样该类就不会被实例化
private Singleton(){}
//获取唯一可用的对象
public static Singleton getInstance(){
return instance;
}
}
```
2. 懒汉式——线程不安全的单例模式
这种方式虽然达到了按需初始化的目的,但却带来了线程不安全的问题,如果多个线程同时调用 `getInstance()` 方法,那么就会创建多个实例。
```java
public class Singleton {
private static Singleton instance;
private Singleton(){}
public static Singleton getInstance(){
if(instance == null) {
instance = new Singleton();
}
return instance;
}
}
```
3. 懒汉式——线程安全的单例模式
使用 `synchronized` 关键字可以解决线程安全问题,但是这样每次调用 `getInstance()` 方法都会进行同步,影响程序的性能。
```java
public class Singleton {
private static Singleton instance;
private Singleton(){}
public static synchronized Singleton getInstance() {
if(instance == null) {
instance = new Singleton();
}
return instance;
}
}
```
4. 双重校验锁——线程安全的单例模式
这是一种比较好的实现方式,使用了双重校验锁,既保证了线程安全,又实现了按需初始化,同时也减少了同步开销。
```java
public class Singleton {
private volatile static Singleton instance;
private Singleton(){}
public static Singleton getInstance() {
if(instance == null) {
synchronized (Singleton.class) {
if(instance == null) {
instance = new Singleton();
}
}
}
return instance;
}
}
```
5. 静态内部类——线程安全的单例模式
使用静态内部类的方式可以在调用 `getInstance()` 方法时才真正创建对象,达到最佳的按需初始化效果,并且也保证了线程安全。
```java
public class Singleton {
private Singleton(){}
private static class SingletonHolder{
private static final Singleton INSTANCE = new Singleton();
}
public static Singleton getInstance(){
return SingletonHolder.INSTANCE;
}
}
```