Android中常用哪一种单例

13 篇文章 0 订阅
5 篇文章 0 订阅

在Android开发中,静态内部类(Initialization-on-demand holder idiom)和枚举单例(Enum Singleton)是最常用的单例实现方式。这是因为它们在保证线程安全的同时具有良好的性能和简洁的代码实现。以下是详细的解释:

1. 静态内部类(Initialization-on-demand holder idiom)

实现
public class Singleton {
    private Singleton() {}

    private static class Holder {
        private static final Singleton INSTANCE = new Singleton();
    }

    public static Singleton getInstance() {
        return Holder.INSTANCE;
    }
}
优点
  • 线程安全:由JVM保证类加载的线程安全性,不需要额外的同步。
  • 懒加载:实例在第一次使用时才会创建,节省资源。
  • 性能好:不使用 synchronized,性能开销低。
  • 实现简单:代码简洁易读。
为什么常用
  • 适用于大多数情况:大多数单例类在第一次使用之前都不需要实例化,静态内部类方式在这方面表现非常出色。
  • 避免同步开销:相比于同步方法或双重检查锁定,静态内部类方式没有同步开销,性能优越。

2. 枚举单例(Enum Singleton)

实现
public enum Singleton {
    INSTANCE;

    public void doSomething() {
        // 功能实现
    }
}
优点
  • 线程安全:枚举类型的单例实现由JVM本身提供线程安全保证。
  • 防止反射攻击:枚举类型天然防止反射攻击。
  • 序列化:自动支持序列化机制,防止反序列化重新创建新的对象。
  • 实现简单:代码非常简洁。
为什么常用
  • 最简单的单例实现:没有比枚举类型更简单的单例实现方式,代码极其简洁。
  • 安全性高:防止反射和序列化攻击,适合需要高安全性的场景。

选择哪种单例

在实际开发中,选择哪种单例实现方式取决于具体需求:

  • 一般情况:使用静态内部类方式,适合大多数单例需求,性能好,代码简洁。
  • 高安全性需求:使用枚举单例,防止反射攻击和反序列化破坏单例特性。

示例:Android开发中的应用

静态内部类示例
public class NetworkManager {
    private NetworkManager() {}

    private static class Holder {
        private static final NetworkManager INSTANCE = new NetworkManager();
    }

    public static NetworkManager getInstance() {
        return Holder.INSTANCE;
    }

    public void doNetworkOperation() {
        // 网络操作
    }
}
枚举单例示例
public enum PreferencesManager {
    INSTANCE;

    public void savePreference(String key, String value) {
        // 保存偏好设置
    }

    public String getPreference(String key) {
        // 获取偏好设置
        return "";
    }
}

结论

在Android开发中,静态内部类和枚举单例是常用的单例实现方式。静态内部类方式因其线程安全、懒加载、性能好和实现简单等优点,适用于大多数情况。而枚举单例则因其防反射和序列化攻击的特性,适合需要高安全性的场景。在实际项目中,选择哪种方式可以根据具体需求进行权衡。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

彬_小彬

你的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值