我试图理解别人编写的Java程序,但我不知道Java。我已经写了一个简短的方法来转储请求对象的属性。

public void dumpRequest(HttpServletRequest request) {

    String[] attrNames = new String[100]; // hard coded
    int ani = 0;

    Enumeration rns = request.getAttributeNames();
    while (rns.hasMoreElements()) {
        out.println("attribute name: " + rns.nextElement());
        attrNames[ani] = rns.nextElement().toString();
        ani = ani + 1;
    }

    out.println("" + ani + " atributes");
    String cn;
    for (int n = 0; n < ani; n++) {
        cn = attrNames[n];
        out.println("** " + cn + " - " + request.getAttribute(cn));
    }
    out.println("++++++++++++++++++++++");

}


令我震惊的是,我意识到与代码输出相比,NetBeans变量选项卡在请求对象上显示的属性多两倍。
该枚举似乎记录在这里:
https://tomcat.apache.org/tomcat-4.1-doc/catalina/docs/api/org/apache/catalina/util/Enumerator.html

我究竟做错了什么?

最佳答案

您在此块中两次调用nextElement方法:

while (rns.hasMoreElements()) {
        out.println("attribute name: " + rns.nextElement());
        attrNames[ani] = rns.nextElement().toString();
        ani = ani + 1;
    }


您应该一次调用nextElement。将其放在变量中,然后使用该变量。

08-07 22:38