0

I have this object:

public class Customer {

    private String id;
    private String name;
    private String cf;
    private String pi;
    private String telephone;
    private String email;
    private String website;
    private String sector;
    private String address;

    //constructor and getter, setter method

}

and a Map of Customer into main:

Map<String, Customer> customerMap = new HashMap<>();
customerMap.put("1", customer1);
customerMap.put("2", customer2);
...

sortMapByName(customerMap);

I want to order it by name attribute.

I use the solution at this link: How to sort a Map in Java

Code:

public void sortMapByName(Map<String, Customer> unsortMap) {

    // Convert Map to List
    List<Map.Entry<String, Customer>> list = new LinkedList<>(unsortMap.entrySet());

    // Sort list with comparator, to compare the Map values
    Collections.sort(list, new Comparator<Map.Entry<String, Customer>>() {

        @Override
        public int compare(Map.Entry<String, Customer> o1, Map.Entry<String, Customer> o2) {
            return (o1.getValue().getName()).compareTo(o2.getValue().getName());
        }
    });

    // Convert sorted map back to a Map
    listCustomer = new LinkedHashMap<>();
    for (Map.Entry<String, Customer> entry : list) {
        listCustomer.put(entry.getKey(), entry.getValue());
    }

}

it doesn't work, why?

UPDATE

Please, try it.

Customer.java

public class Customer {

private String id;
private String name;
private String cf;
private String pi;
private String telephone;
private String email;
private String website;
private String sector;
private String address;

public Customer() {
}

public Customer(String id, String name, String cf, String pi, String telephone, String email, String website, String sector, String address) {
    this.id = id;
    this.name = name;
    this.cf = cf;
    this.pi = pi;
    this.telephone = telephone;
    this.email = email;
    this.website = website;
    this.sector = sector;
    this.address = address;
}

public String getId() {
    return id;
}

public void setId(String id) {
    this.id = id;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public String getCf() {
    return cf;
}

public void setCf(String cf) {
    this.cf = cf;
}

public String getPi() {
    return pi;
}

public void setPi(String pi) {
    this.pi = pi;
}

public String getTelephone() {
    return telephone;
}

public void setTelephone(String telephone) {
    this.telephone = telephone;
}

public String getEmail() {
    return email;
}

public void setEmail(String email) {
    this.email = email;
}

public String getWebsite() {
    return website;
}

public void setWebsite(String website) {
    this.website = website;
}

public String getSector() {
    return sector;
}

public void setSector(String sector) {
    this.sector = sector;
}

public String getAddress() {
    return address;
}

public void setAddress(String address) {
    this.address = address;
}

Main.java

public class Main { 

public static void main(String[] args) {

    Map<String, Customer> unsortedMap = new HashMap<>();

    Customer one = new Customer("1", "B", "bbb", "1234", "bbb", "gmail.com", "none", "student", "Italy");
    Customer two = new Customer("2", "C", "ccc", "1234", "ccc", "gmail.com", "none", "student", "Italy");
    Customer three = new Customer("3", "A", "aaa", "1234", "aaa", "gmail.com", "none", "student", "Italy");

    unsortedMap.put("1", one);
    unsortedMap.put("2", two);
    unsortedMap.put("3", three);

    System.out.print("Before: \n"+unsortedMap);

    Map<String, Customer> sortedMap = sortMapByName(unsortedMap);

    System.out.print("\n\nAfter: \n"+sortedMap);
}

public static Map<String, Customer> sortMapByName(Map<String, Customer> unsortMap) {

    // Convert Map to List
    List<Map.Entry<String, Customer>> list = new LinkedList<>(unsortMap.entrySet());

    // Sort list with comparator, to compare the Map values
    Collections.sort(list, new Comparator<Map.Entry<String, Customer>>() {

        @Override
        public int compare(Map.Entry<String, Customer> o1, Map.Entry<String, Customer> o2) {
            return (o1.getValue().getName()).compareTo(o2.getValue().getName());
        }
    });

    // Convert sorted map back to a Map
    Map<String, Customer> sortedMap = new LinkedHashMap<>();
    for (Iterator<Map.Entry<String, Customer>> it = list.iterator(); it.hasNext();) {
        Map.Entry<String, Customer> entry = it.next();
        sortedMap.put(entry.getKey(), entry.getValue());
    }

    return sortedMap;

}

}
Dave
  • 1,428
  • 4
  • 31
  • 49
  • Hash map stores values where key is hash value of object. See http://stackoverflow.com/questions/21974361/what-java-collection-should-i-use Use TreeMap – Robert Wadowski Jul 04 '15 at 20:29
  • @RobertWadowski, you didn't read his code. It's taking in a HashMap, but he's putting the values into a LinkedHashMap, which preserves insertion order for when iterating. – Dogs Jul 04 '15 at 20:33
  • sorry I didn't finish last 3 lines – Robert Wadowski Jul 04 '15 at 20:36
  • I have update the question, can you try the code? Thanks Update: works! – Dave Jul 04 '15 at 20:57

1 Answers1

2

You need to use the sorted map in the method. Change the type from void to Map<String, Customer and add return listCustomer; at the end. The original map is simply preserved unchanged in your current code.

public Map<String, Customer> sortMapByName(Map<String, Customer> unsortMap) {

   ...
   return listCustomer;
}

If, for some reason, listCustomer is a class member, make sure you use that instead of the original unsorted one.

UPDATE: When printing the map, you can loop over the map entries:

for (Iterator<String> iterator = sortedMap.keySet().iterator(); iterator.hasNext();) {
    Customer cust = sortedMap.get(iterator.next());
    System.out.println(cust);   
}

You'd also need to override the toString() method in Customer to print something useful, something like:

@Override
public String toString() {
    return "Customer [id=" + id + ", name=" + name + ", cf=" + cf + ", pi="
            + pi + ", telephone=" + telephone + ", email=" + email
            + ", website=" + website + ", sector=" + sector + ", address="
            + address + "]";
}
M A
  • 71,713
  • 13
  • 134
  • 174
  • 1
    He should do what you are saying. But he is assigning his results to `listCustomer`, which appears to be defined outside the sorting method. So maybe it's on purpose? So maybe his problem is something else? – sstan Jul 04 '15 at 20:35
  • I have update the question, please try the code.. Update: works! – Dave Jul 04 '15 at 20:56
  • 1
    @DavideFruci It works fine. You're just not printing the map clearly to show the `name` field. See my update. – M A Jul 04 '15 at 21:10