0

我有几张表已SELECT *写入 XML 文件。让我们称它们为映射到 java 类 A、B 和 C 的表 A、B 和 C。与其制作单独的 AXMLDao、BXMLDao 和 CXMLDao,我希望拥有一个通用类。

A、B 和 C 具有映射到各自的 A、B 和 C 表的成员变量。我public static Map<String, Method> getSetMethodMap()在每个 A、B、C 类中都有使用反射 API 返回数据库字段名称到相应类中的 mutator 方法的映射。

我已经做了一个当前的实现,但它在两个方面失败了:1)它充满了警告,因为我没有正确地做,2)我不确定我如何能够getSetMethodMap()通过类型参数访问。

如果我使用非静态方法创建一个名为 ReflectionType 的接口public Map<String,Method> getMethodMap();并将以下实现更改为,<T extends ReflectionType>那么我可以设置 methodMap.. 但这感觉不对。

这是我目前的实现。

public class GenericXMLDao<T> extends DefaultHandler {
    List<T> rows;
    String xmlFileName;
    Map<String, Method> methodMap; // This is for Reflection API
    T tempRow;

    String tempValue;

    public static Map<Class, String> getXMLFileMap() {
        Map<Class, String> map = new HashMap<Class, String>();
        map.put("A.class", "C:\\A.xml");
        ....
        return map;
    }

    public String fetchXMLFileName(Class c) {
        Map<Class,String> map = GenericXMLDao.getXMLFileMap();
        // Try Catch Throw exception if Class is not in map, but essentially:
        return map.get(c);
    }

    public List<T> getAllRows(Class c) {
        rows = new ArrayList<T>();
        xmlFileName = fetchXMLFileName(c);
        parseDocument();
        return rows;
    }

    private void parseDocument() {
        SAXParserFactory factory = SAXParserFactory.newInstance();
        try {
            SAXParser parser = factory.newSAXParser();
            parser.parse(xmlFileName, this);
        // catch ....
    }

    @Override
    public void startElement(String s, String s1, String elementName, Attributes attributes)
            throws SAXException {
        if (elementName.equalsIgnoreCase("DATA_RECORD")) {
            try {
                tempRow = (T) tempRow.getClass().newInstance();
            } catch (InstantiationException | IllegalAccessException e) {
                ...
            }
        }
    }
}

@Override
public void endElement(String s, String s1, String element) throws SAXException {
    if (element.equals("DATA_RECORD")) {
        rows.add(tempRow);
    }

    for (Entry<String,Method> entry : methodMap.entrySet()) {
        // Try ... catch reflection api
        if (element.equalsIgnoreCase(entry.getKey))) {
            entry.getValue().invoke(tempRow, tempValue);
        }
    }
}

@Override
public void characters(char[] ac, int i, int j) throws SAXException {
    tempValue = new String(ac, i, j);
}

我显然没有正确掌握泛型/类型参数化。

这怎么能清理干净?

4

1 回答 1

0

至于我,

<T extends ReflectionType>

T如果您需要调用类的某些方法(如getSetMethodMap本例中),这是要走的路。

于 2013-10-02T07:13:13.860 回答