使用围绕XML存储的对象的无类型包装类,这是不是很糟糕?

And*_*wKS 5 java types

class MyThing {
    protected HashMap<String,Object> fields;

    protected MyThing(HashMap<String,Object> newFields){
        fields.putAll(newFields);
    }

    protected Object get(String key){
        return fields.get(key);
    }
}
Run Code Online (Sandbox Code Playgroud)

现在有点背景.我使用这个类作为一个超类来代表一堆不同的类,它们代表XML文件中的对象.这基本上是API包装器的实现,我将其用作API中的解析XML和数据库之间的适配器.转换被委托给get方法的调用者.如果子类在创建时或者返回变量时需要执行某些操作,则只需调用super,然后操作之后返回的内容.例如.:

class Event extends MyThing {       
    public Event(HashMap<String,Object> newFields){
        super(newFields);

        // Removes anything after an @ symbol in returned data
        Pattern p = Pattern.compile("\\@.*$");
        Matcher m = p.matcher((String)fields.get("id"));
        boolean result = m.find();

        if (result)
            fields.put("id", m.replaceFirst(""));
        }
    }

    public Object get(String key){
        Object obj = super(key);

        if (key.equals("name")){
            return "Mr./Mrs. " + ((String)obj);
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

我觉得我应该这样做的原因是因为它们具有不同的属性,所以我不必为每个子类编写getId,getName,getWhatever方法.它可以节省时间,而且非常自我解释.

现在这显然是"unJavalike",而且更像是一种半语言的做事方式,但是有理由说我绝对不应该这样做吗?

Sto*_*ica 2

  1. 显然,它不是类型安全的。
  2. 未来的维护者不会知道这些类型应该是什么,并且通常会对为什么不使用 POJO 感到困惑。
  3. 您拥有 HashMap 的特性,而不是恒定的时间、空间复杂度和性能。
  4. 将来编写不平凡的 getter/setter 会变得非常困难。
  5. 大多数数据绑定系统都设计为与 POJO/Bean(JAXB、JPA、Jackson 等)配合使用。

我确信还有更多,但这个就可以了。尝试使用一些合适的 OXM 库,你的情况会好得多。