1

我编写了两个应该填充 GridBagLayout 的 for 循环。不知何故,第二个条件没有起作用,因此我得到了一个例外。

所以基本上程序的作用是:它从 MySQL 服务器获取数据并将其列在 GridBagLayout 中。rs.lenght因此,我通过使用and获得了行的长度rs.getRow()。比我将它复制到lenghtCounter内部 for 循环(使用 x 变量)。内部 for 循环应在 3 个周期后执行,或者如果 lenghtCounter 等于 0。我在控制台中看到计数器正常工作并按预期下降到 0,但 for 循环不会中断。相反,它继续并给了我一个例外。

这是代码:

        try {
            ResultSet rs = MySQL.getStatement().executeQuery(
                    "select * from obj_house");
            rs.last();
            int lenghtCounter = rs.getRow();
            int lenght = lenghtCounter;
            rs.first();
            System.out.println(lenghtCounter + " " + (lenght / 3));

            for (int y = 0; y <= (lenght / 3); y++) {
                for (int x = 0; x < 3 || lenghtCounter==0; x++) {
                    System.out.println("ID " + lenghtCounter);

                    JButton street = new JButton("Strasse: " + rs.getString(5));

                    gbcOut.gridx = x;
                    gbcOut.gridy = y;
                    panelBottom.add(street, gbcOut);

                    System.out.println("X: " + x);
                    System.out.println("Y: " + y);
                    rs.next();
                    lenghtCounter--;
                    System.out.println("lenght: " + lenghtCounter);
                }
            }
        } catch (SQLException e1) {
            // TODO Auto-generated catch block
            e1.printStackTrace();
        }
4

4 回答 4

3

尝试测试:

x < 3 && lenghtCounter>0
于 2013-10-29T13:58:28.220 回答
2

||在这里不会按预期工作,因为 for 循环条件以另一种方式工作。for 循环条件与 while 循环条件相同。当您指定的条件评估为 时,循环中断false。因此,按照您指定的方式,循环将 x < 3 || lenghtCounter == 0.

我想你想要的是:

x < 3 && lenghtCounter != 0

或者:

x < 3 && lenghtCounter > 0.

(还有 lenghtCounter 一个错字?)

于 2013-10-29T14:10:30.183 回答
1

你可能不需要 || lenghtCounter==0. 当 lengthCounter 达到 0rs.next()时,您会额外调用一次,这就是您可能会遇到异常的原因。

于 2013-10-29T13:59:09.383 回答
1

如果我不得不猜测您试图在外部循环运行三遍之前不运行内部循环。但是,每次外部循环运行时,x 都会因范围而重置为 0。重新检查您的范围 - 在循环之前声明 x 。

此外,您的外部循环本身不会做任何事情。您可能希望切换到带有 x 和 y 的多个逻辑增量器的 while 循环。

于 2013-10-29T13:59:14.643 回答