1
import java.util.Scanner;
public class InteractiveRectangle
{
public static void main(String[] args)
{
    do 
    { 
        int length = readInteger ("For Length ");
        System.out.println();
        int width = readInteger ("For Width ");
        printRectangleDetails(length,width);// existing code goes here 
    } 
    while (keepGoing()); 

    System.out.println("Goodbye, friend"); 
}


/**
 * returns the details of the rectangle
 * @param height the height of the rectangle
 * @param width the width of the rectangle
 */
public static void printRectangleDetails (int length, int width)
{
    System.out.println ("This is the length of the rectangle " + length);

    System.out.println ("This is the width of the rectangle " + width);

    System.out.println (("This is the perimeter of the rectangle " + (length + width)));

    System.out.println (("This is the area of the rectangle " + (length * width)));
}

/**
 * Read in an integer and return its value
 * @param the prompt to be shown to the user
 */
public static int readInteger(String prompt)
{
    System.out.println (prompt);
    Scanner scan = new Scanner(System.in);
    System.out.println("Enter an integer");

    while (!scan.hasNextInt()) // while non-integers are present
    {
        scan.next();
        System.out.println ("Bad input. Enter an integer.");
    }
    int input = scan.nextInt();
    return input;
}

/**
 * Read a positive integer and return its value
 * @param the prompt to be shown to the user
 */
public static int readPositiveInteger(String prompt)
{
    System.out.println (prompt);
    Scanner scan = new Scanner(System.in);
    System.out.println("Enter an integer");
    boolean positive = false;

    while (scan.hasNextInt() && positive == false)
    {
        int input = scan.nextInt();
        if (input > 0)
        {
            positive = true;
            {
                return input;
            }
        }
        else
        {
            System.out.println ("Bad input enter an integer.");
            positive = false;
            scan.nextLine();

        }

    }
    return 0;
}

/**
 * Ask the user whether or not to spawn another rectangle
 * and returns the result as a boolean
 */
public static boolean keepGoing()    
{
    Scanner scan = new Scanner(System.in);
    boolean inputRead = false;
    boolean result = false;
    System.out.println ("Do you want to process another rectangle?"); 
    scan.next();
    String input = scan.next();

    if (input == "y")
    {
        inputRead = true;
        result = true;

    }
    else if (input == "n")
    {
        inputRead = true;
        result = false;

    }
    else
    {
        System.out.println("Bad input please try again!");
        scan.nextLine();
    }
    return result;

}

}

我希望程序询问用户是否要生成另一个矩形,并继续运行直到用户用“n”回答这个问题。Atm 运行程序时,矩形只生成一次,所以我认为我的 keepGoing 方法有问题。任何帮助将不胜感激,谢谢!

4

5 回答 5

4

if (input == "y")

总是将字符串与equals()

你需要

if ("y".equals(input))

或者

if ("y".equalsIgnoreCase(input)) // will also allow Y

相应地更改其他检查。

于 2012-11-23T06:15:41.183 回答
2

是的,有几个问题: -

  • 首先,您使用==运算符比较字符串,这始终是错误的。使用equals方法:-

    if (input.equals("y"))   // or,   if (input.equalsIgnoreCase("y"))
    
  • 其次,你不应该使用scan.next()方法,你正在使用的方式。您的第一个scan.next应分配给input,因为您的第二个scan.next包含换行符:-

    System.out.println ("Do you want to process another rectangle?"); 
    // scan.next();  // Should not be here.
    String input = scan.next();
    scan.next();     // Change the order
    

    或者,只需使用scan.nextLine(): -

    System.out.println ("Do you want to process another rectangle?"); 
    String input = scan.nextLine();
    
  • 第三,就您而言else,您可以keepGoing再次调用您的方法,而不是在那里读取输入:-

    else
    {
        System.out.println("Bad input please try again!");
        return keepGoing();
    }
    
  • 此外,在您的if-else, 而不是将布尔值设置为变量,您可以直接从那里返回。

因此,总而言之,您可以将您的更改if-else if-else为: -

if (input.equals("y")) {
    return true;
}
else if (input.equals("n")) {
    return false;
}
else
{
    System.out.println("Bad input please try again!");
    return keepGoing();
}

然后,您不需要这些boolean变量: -inputReadresult. 只需删除它们。并returnmethod. 就像unreachable code现在一样。

于 2012-11-23T06:18:38.697 回答
1

总是用 .equals() 比较字符串

 if (input == "y")

替换为

 if (input.equals("y"))
于 2012-11-23T06:16:41.170 回答
1

您正在使用运算符检查两个字符串是否相等==。始终使用 equals 方法检查字符串是否相等。

if (input == "y")

应该

if (input.equals("y"))

以及在其他地方,

==运算符检查两个字符串引用是否指向同一个字符串对象。equals 方法确定两个 String 对象是否有意义地相等。

于 2012-11-23T06:17:26.257 回答
1

这段代码:

if (input.equals("y"))
{
    inputRead = true;
    result = true;

}
else if (input.equals("n"))
{
    inputRead = true;
    result = false;

}

应该解决问题。请记住,Java 中的对象是通过引用而不是值进行比较的。

于 2012-11-23T06:18:23.643 回答