【问题标题】:(Beginner Java issues) Why isn't this code working?(Java 初学者问题)为什么这段代码不起作用?
【发布时间】:2013-02-05 01:15:42
【问题描述】:

(完整代码如下) 我刚刚提交了一个课堂实验室,我们必须制作一个描述某本书的课程。我不知道如何做两件事。 1. 如果有人为 'pages' 或 'suggestedRetailPrice' 输入小于零的值,则该值 必须设置为零。在此代码中,即使该值为正,该值也设置为 0。在:


if ( pages <= 0 )
    {
        pages = 0;
    }

如果我将第二个“0”设置为不同的数字,例如:


if ( pages <= 0 )
    {
        pages = 1;
    }

那么你为'pages'输入的任何值都是1。但是如果你输入的值是负数,它不应该是1吗?我不明白我做错了什么。

我想不通的第二件事是在代码的底部,我们必须显示所有信息。我的老师希望我们用“是”或“否”而不是“真”或“假”来显示这本书是否是平装本。我该怎么做呢?我尝试像这样放置 if/else 语句: System.out.println("平装本:" + if (paperback = true) {Yes} if (paperback = false) {no}; )

没用,想不通。请参阅下面的完整代码。


public class Book {
    // Instance variables
    private String title;
    private String author;
    private int isbn;
    private int pages;
    private boolean paperback;
    private int suggestedRetailPrice;

    /**
     * Default contructor
     */
    public Book() {
        title = "";
        author = "";
        isbn = 0;
        pages = 0;
        paperback = false;
        suggestedRetailPrice = 0;
    }

    /**
     * book information
     */
    public Book(String whatIsTitle, String whoIsAuthor, int isbnCode,
            int numberOfPages, boolean isItPaperback,
            int theSuggestedRetailPrice) {
        title = whatIsTitle;
        author = whoIsAuthor;
        isbn = isbnCode;
        if (pages <= 0) {
            pages = 0;
        } else {
            pages = numberOfPages;
        }
        paperback = isItPaperback;
        if (suggestedRetailPrice <= 0) {
            suggestedRetailPrice = 0;
        } else {
            suggestedRetailPrice = theSuggestedRetailPrice;
        }
    }

    /**
     * @return title
     */
    public String getTitle() {
        return title;
    }

    /**
     * @return author
     */
    public String getAuthor() {
        return author;
    }

    /**
     * @return isbn
     */
    public int getIsbn() {
        return isbn;
    }

    /**
     * @return pages
     */
    public int getPages() {
        return pages;
    }

    /**
     * @return paperback
     */
    public boolean getPaperback() {
        return paperback;
    }

    /**
     * @return suggestedRetailPrice
     */
    public int getSuggestedRetailPrice() {
        return suggestedRetailPrice;
    }

    /**
     * title
     */
    public void setTitle(String whatIsTitle) {
        title = whatIsTitle;
    }

    /**
     * author
     */
    public void setAuthor(String whoIsAuthor) {
        author = whoIsAuthor;
    }

    /**
     * isbn code
     */
    public void setIsbn(int isbnCode) {
        isbn = isbnCode;
    }

    /**
     * number of pages
     */
    public void setPages(int numberOfPages) {
        if (pages <= 0) {
            pages = 0;
        } else {
            pages = numberOfPages;
        }
    }

    /**
     * is it paperback
     */
    public void setPaperback(boolean isItPaperback) {
        paperback = isItPaperback;
    }

    /**
     * suggested retail price
     */
    public void setSuggestedRetailPrice(int theSuggestedRetailPrice) {
        if (suggestedRetailPrice <= 0) {
            suggestedRetailPrice = 0;
        } else {
            suggestedRetailPrice = theSuggestedRetailPrice;
        }
    }

    /**
     * displays information
     */
    public void displayBook() {
        System.out.println("Title : " + title);
        System.out.println("Author : " + author);
        System.out.println("ISBN : " + isbn);
        System.out.println("Pages : " + pages);
        System.out.println("Paperback : " + paperback);
        System.out.println("Suggested price : " + suggestedRetailPrice);
    }
}

【问题讨论】:

    标签: java


    【解决方案1】:

    您正在检查页面值之前使用参数 numberOfPages 设置它:

     title = whatIsTitle;
     author = whoIsAuthor;
     isbn = isbnCode;
    
     // pages is still at its initialzed value of 0 here.
     if ( pages <= 0 )
     {
         pages = 0;
     }
     else
     {
         pages = numberOfPages; // this will *never* be called
     } 
    

    颠倒这个顺序。或者更好的是,检查参数值并使用它来设置您的页面值:

    if (numberOfPages < 0) {
       pages = 0;
    } else {
       pages = numberOfPages
    }
    

    对于您的第二个问题,创建一个名为 isPaperback 的字符串,如果平装本为真,则将其设置为“是”字符串到您的输出字符串,如果不是,则将其设置为“否”,然后在需要时显示该字符串。要么把你的 System.out.println("yes") 放在一个 if 块中,测试平装本的价值。

    即,

    if (paperback) {
       System.out.println(...);
    } else {
       System.out.pringln(...);
    }
    

    【讨论】:

    • 谢谢你的帮助,我现在明白了:)
    【解决方案2】:

    我有点不确定您要做什么,但我注意到在 Book 类中,当参数为“numberOfPages”时,您正在使用“pages”。尝试做

    if(numberOfPages <= 0) pages = 0
    

    此外,如果你能弄清楚如何使用三元运算符,你可以让这一切变得整洁漂亮,但我会把这个留给你。

    至于打印语句,将“if”放在打印之外。

    if(paperback) System.out.println("Paperback: Yes")
    else System.out.println("Paperback: no)
    

    另外,这是三元运算符的另一个好地方。

    【讨论】:

      猜你喜欢
      • 2018-06-14
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2010-09-18
      相关资源
      最近更新 更多