使用静态类而不是单例模式?

时间:2012-01-09 13:26:58

标签: java design-patterns

我已经阅读了this问题和一些类似的问题,我想知道是否有任何情况我应该在单例模式上使用静态类?

2 个答案:

答案 0 :(得分:7)

当你有“只是代码”方法时,使用静态“实用程序”类(只有静态方法的类) - 你需要基类的任何特定实现的方法或者接口。关键指标是代码是无状态 - 即类中没有(静态)字段给它状态。无状态也意味着这些方法是自动线程安全的 - 另一个好处。

JDK中有很多例子(Collections是一个值得注意的例子),这种模式的apache commons libraries运作良好。

此外,为避免“类膨胀”,而不是为特定的简单实现提供类,您可以使用返回特定实现的静态(抽象)工厂方法,例如:

public static Comparator<String> createCaselessStringCompatator() {
    return new Comparator<String> () {
        public int compare(String o1, String o2) {
            return o1.toUpperCase().compareTo(o2.toUpperCase());
        }
    }; 
}

public static Comparator<String> createNumericStringCompatator() {
    return new Comparator<String> () {
        public int compare(String o1, String o2) {
            return new Double(o1).compareTo(new Double(o2));
        }
    }; 
}

这种模式可以避免创建一个全新的类文件,只需要一行实际有用的代码(例如“closure”)它将它们捆绑在一起,所以如果你知道你的实用程序类名,你的IDE会提示你选择哪个impl:

Collections.sort(myStringList, MyComparators.|<-- ctrl+space to offer options

如果没有这种模式,你必须记住每个实现的类名。

答案 1 :(得分:1)

我认为这种情况下你需要一些实用功能的地方,这些功能又是静态的。