比较双重不起作用

时间:2014-07-25 15:28:38

标签: java sorting comparator

我开发了一个程序,可以创建一个Book Objects数组,并根据用户输入对它们进行排序。排序选项是作者 - 标题 - 页面 - 价格,所有工作,但价格排序。 请帮我找到为什么我不能使用Comparator排序双打...... 我的SchoolTextBook课程:

import java.util.Comparator;


public class SchoolTextBook {

private String author;
private String title;
private int pageCount;
private String ISBN;
private double price;

public String getAuthor() {
    return author;
    }
public void setAuthor(String author) {
    this.author = author;
    }

public String getTitle() {
    return title;
    }
public void setTitle(String title) {
    this.title = title;
    }

public int getPageCount() {
    return pageCount;
}
public void setPageCount(int pageCount) {
    this.pageCount = pageCount;
}

public String getISBN() {
    return ISBN;
}
public void setISBN(String iSBN) {
    ISBN = iSBN;
}

public double getPrice() {
    return price;
}
public void setPrice(double price) {
    this.price = price;
}

public static Comparator<SchoolTextBook> BookAuthorComparator 
                    = new Comparator<SchoolTextBook>() {

    public int compare(SchoolTextBook book1, SchoolTextBook book2) {

        String bookName1 = book1.getAuthor().toUpperCase();
        String bookName2 = book2.getAuthor().toUpperCase();

        //ascending order
        return bookName1.compareTo(bookName2);

    }

};

public static Comparator<SchoolTextBook> BookTitleComparator 
                    = new Comparator<SchoolTextBook>() {

    public int compare(SchoolTextBook book1, SchoolTextBook book2) {

        String bookName1 = book1.getTitle().toUpperCase();
        String bookName2 = book2.getTitle().toUpperCase();

        //ascending order
        return bookName1.compareTo(bookName2);

    }

};
public static Comparator<SchoolTextBook> BookPagesComparator 
                    = new Comparator<SchoolTextBook>() {

    public int compare(SchoolTextBook book1, SchoolTextBook book2) {

        int bookName1 = book1.getPageCount();
        int bookName2 = book2.getPageCount();

        //ascending order
        return bookName1 - bookName2;

    }

};

public static Comparator<SchoolTextBook> BookPriceComparator 
                    = new Comparator<SchoolTextBook>() {

    public int compare(SchoolTextBook book1, SchoolTextBook book2) {

        double bookName1 = book1.getPrice();
        double bookName2 = book2.getPrice();
        //ascending order
        return (int) (bookName1 - bookName2);

    }

};
}

排序程序:

import java.util.Arrays;
import java.util.*;

import javax.swing.*;

public class SchoolTextBookSort {

public static void main(String[] args) {
    // TODO Auto-generated method stub

    String[] choices = {"Author", "Title", "Page Count", "Price"};

    SchoolTextBook[] theBooks = new SchoolTextBook[5];

    theBooks[0] = new SchoolTextBook();
    theBooks[1] = new SchoolTextBook();
    theBooks[2] = new SchoolTextBook();
    theBooks[3] = new SchoolTextBook();
    theBooks[4] = new SchoolTextBook();

    theBooks[0].setAuthor("Ernest Hemingway");
    theBooks[1].setAuthor("Mark Twain");
    theBooks[2].setAuthor("William Shakespeare");
    theBooks[3].setAuthor("Stephen King");
    theBooks[4].setAuthor("William Faulkner");

    theBooks[0].setTitle("A Farewell to Arms");
    theBooks[1].setTitle("The Adventures of Huckleberry Finn");
    theBooks[2].setTitle("Hamlet");
    theBooks[3].setTitle("Salem's Lot");
    theBooks[4].setTitle("The Sound and the Fury");

    theBooks[0].setPageCount(332);
    theBooks[1].setPageCount(320);
    theBooks[2].setPageCount(196);
    theBooks[3].setPageCount(439);
    theBooks[4].setPageCount(326);

    theBooks[0].setISBN("0099910101");
    theBooks[1].setISBN("0142437174");
    theBooks[2].setISBN("0521618746");
    theBooks[3].setISBN("0450031063");
    theBooks[4].setISBN("0679732241");

    theBooks[0].setPrice(5.99);
    theBooks[1].setPrice(7.60);
    theBooks[2].setPrice(9.41);
    theBooks[3].setPrice(16.56);
    theBooks[4].setPrice(9.60); 


    int response = JOptionPane.showOptionDialog(
            null                                        // Center in window.
          , "Please select a method to sort the books." // Message
          , "Sort Text Books"                           // Title in titlebar
          , JOptionPane.YES_NO_OPTION                   // Option type
          , JOptionPane.PLAIN_MESSAGE                   // messageType
          , null                                        // Icon (none)
          , choices                                     // Button text as above.
          , null                                        // Default button's label
        );

    //... Use a switch statement to check which button was clicked.
    switch (response) {
    case 0: 
        Arrays.sort(theBooks, SchoolTextBook.BookAuthorComparator);
        break;
    case 1:
        Arrays.sort(theBooks, SchoolTextBook.BookTitleComparator);
        break;
    case 2:
        Arrays.sort(theBooks, SchoolTextBook.BookPagesComparator);
        break;
    case 3:
        Arrays.sort(theBooks, SchoolTextBook.BookPriceComparator);
    case -1:
        //... Both the quit button (3) and the close box(-1) handled here.
        System.exit(0);     // It would be better to exit loop, but...
    default:
        //... If we get here, something is wrong.  Defensive programming.
        JOptionPane.showMessageDialog(null, "Unexpected response " + response);
    }

    show(theBooks);


}

public static String show(SchoolTextBook[] theBooks) {
    StringBuilder sb = new StringBuilder(64);
    sb.append("<html><table><tr><td>Author</td><td>Title</td><td>ISBN</td><td>Pages</td><td>Price</td></tr>");
    sb.append("<tr>");
    sb.append("<td>").append(theBooks[0].getAuthor()).append("</td>");
    sb.append("<td>").append(theBooks[0].getTitle()).append("</td>");
    sb.append("<td>").append(theBooks[0].getISBN()).append("</td>");
    sb.append("<td>").append(theBooks[0].getPageCount()).append("</td>");
    sb.append("<td>").append("$" + theBooks[0].getPrice()).append("</td></tr>");
    sb.append("<tr>");
    sb.append("<td>").append(theBooks[1].getAuthor()).append("</td>");
    sb.append("<td>").append(theBooks[1].getTitle()).append("</td>");
    sb.append("<td>").append(theBooks[1].getISBN()).append("</td>");
    sb.append("<td>").append(theBooks[1].getPageCount()).append("</td>");
    sb.append("<td>").append("$" + theBooks[1].getPrice()).append("</td></tr>");
    sb.append("<tr>");
    sb.append("<td>").append(theBooks[2].getAuthor()).append("</td>");
    sb.append("<td>").append(theBooks[2].getTitle()).append("</td>");
    sb.append("<td>").append(theBooks[2].getISBN()).append("</td>");
    sb.append("<td>").append(theBooks[2].getPageCount()).append("</td>");
    sb.append("<td>").append("$" + theBooks[2].getPrice()).append("</td></tr>");
    sb.append("<tr>");
    sb.append("<td>").append(theBooks[3].getAuthor()).append("</td>");
    sb.append("<td>").append(theBooks[3].getTitle()).append("</td>");
    sb.append("<td>").append(theBooks[3].getISBN()).append("</td>");
    sb.append("<td>").append(theBooks[3].getPageCount()).append("</td>");
    sb.append("<td>").append("$" + theBooks[3].getPrice()).append("</td></tr>");
    sb.append("<tr>");
    sb.append("<td>").append(theBooks[4].getAuthor()).append("</td>");
    sb.append("<td>").append(theBooks[4].getTitle()).append("</td>");
    sb.append("<td>").append(theBooks[4].getISBN()).append("</td>");
    sb.append("<td>").append(theBooks[4].getPageCount()).append("</td>");
    sb.append("<td>").append("$" + theBooks[4].getPrice()).append("</td>");
    sb.append("</tr></table></html>");
    JOptionPane.showMessageDialog(null, sb);
    return sb.toString();
}

}

3 个答案:

答案 0 :(得分:9)

使用现有的解决方案,您可以将差异转换为int,这在所有情况下均无效,例如2.52.6将解析为(int)(2.6- 2.5) = {{ 1}}这意味着两者都是相同的以避免它

使用Double.compare(double, double)代替

0

答案 1 :(得分:5)

double bookName1 = book1.getPrice();
double bookName2 = book2.getPrice();
//ascending order
return (int) (bookName1 - bookName2);

假设价格为0.99和0.5。因此结果是(int) (0.49),即0。因此,比较器认为两本价格不同的书籍是相同的。

不要将双打加入int,因为它显然会失去精确度。改为使用适当的比较方法:

return Double.compare(book1.getPrice(), book2.getPrice());

答案 2 :(得分:0)

public static int compare(double d1,
          double d2)

比较两个指定的double值。返回的整数值的符号与调用返回的整数的符号相同:

new Double(d1).compareTo(new Double(d2))