2

所以这应该继续循环,直到用户点击“ENTER”或数组被填充。但是在输入数组中的第一个元素后,它会退出循环。

do 
{
    System.out.print("Enter name (or <ENTER> if done): ");
    names[index] = kb.nextLine();
    if(! (names[index].equals(""))) 
    {

        System.out.print("Enter phone number: ");
        phone[index] = kb.nextLine();

        System.out.print("Enter email address: ");
        email[index] = kb.nextLine();

        index++;
        break;
    }
} while ( ! (names[index - 1].equals("")) && index < SIZE);

已更正

do
{
        System.out.print("Enter name (or <ENTER> if done): ");
        names[index] = kb.nextLine();

        if(! (names[index].equals("")))
            {

            System.out.print("Enter phone number: ");
            phone[index] = kb.nextLine();

            System.out.print("Enter email address: ");
            email[index] = kb.nextLine();

            }   
        index++;

    } while ( ! (names[index - 1].equals("")) && index < SIZE);
4

2 回答 2

5

这很简单。break;退出循环。去掉它。

编辑:另外,在您使用的循环条件下[index - 1]。现在,如果您的输入为空(用户按下 Enter),则索引不会增加,它将指向上一个项目。将其更改为just [index],它将起作用。

于 2013-11-14T19:32:50.213 回答
0

问题是break和if语句。工作示例:

do {
    System.out.print("Enter name (or <ENTER> if done): ");
    names[index] = kb.nextLine();

    if (names[index].equals(""))
        break;

    System.out.print("Enter phone number: ");
    phone[index] = kb.nextLine();

    System.out.print("Enter email address: ");
    email[index] = kb.nextLine();

    index++;

} while (index < SIZE);
于 2013-11-14T19:39:53.607 回答