4

我有很多对象使用很少的类(意味着元素视觉分类,如 html+css)。类在编译时是未知的,它们在条件下被多次使用。

为了提高性能,我有一个解决方案:

public class ElementClass {

    private static final Map<String, ElementClass> classes = new HashMap<>();

    public final String name;
    public final String lowerName;

    public ElementClass(String name, String lowerName) {
        this.name = name;
        this.lowerName = lowerName;
    }

    public static ElementClass get(String name) {
        String lower = name.toLowerCase();
        ElementClass c = classes.get(lower);
        if (c == null) {
            c = new ElementClass(name, lower);
            classes.put(lower, c);
        }
        return c;
    }
}

与变量比较相比,该方法get的使用非常少。ElementClass它在解析配置和一些static变量。我不确定这是否是最好的方法,因为我是 Java 初学者。

的示例用法ElementClass

// contains element styles based on it's class
Map<ElementClass,ElementStyle> styles;

void exampleFunction() {
    ElementClass c = ElementClass.get("special");
    for( Element e : elements ) {
        if( e.cls == c ) doSomethingSpecial();
    }
}
4

1 回答 1

1

这将是缓存的教科书实现。如果没有很多 ElementClasses 并且你的程序是单线程的,这就足够了。

我认为没有必要将小写名称保留在ElementClass. 将其用作地图键就足够了。我还假设ElementClass您的项目中还有更多内容,因为现在它只包含一个名称。

更新

澄清后很明显,您确实只打算使用String name. 在这种情况下,最好让每个Element只包含它的小写名称,但interned

public Element(String name) {
  this.name = name.toLowerCase().intern();
}

然后您可以比较element.name == "special"并保证匹配任何等于“特殊”的名称。

于 2012-08-26T18:29:49.090 回答