views:

214

answers:

2

Hi, I am having an Arraylist of Objects. Those object have an attribute or datatype - 'String'. I need to sort the Arraylist by that string. How to achieve this?

+7  A: 

You need to write a Comparator<MyObject> and use Collections.sort(List<T>, Comparator<? super T> to sort your List.

Or else, your MyObject can also implements Comparable<MyObject>, defining a natural ordering that compares on your specific attribute, and then use Collections.sort(List<T> instead.

See also

Related questions

On sorting List on various criteria:

On Comparator and Comparable

polygenelubricants
Thanks! :) Can you elaborate more about the use of comparator and how it will return me sorted objects according to string. Note that I need to sort them in alphabetical order of String.
psvm
Oh. Got the idea about comparator. But I cant implement this interface on the Object because of some other issues. So I need to make Comparator object.
psvm
@Vishal: look at the linked question (Sorting an ArrayList of Contacts). It has the examples you're looking for and more. Also, _Effective Java 2nd Edition, Item 12: Consider implementing Comparable_
polygenelubricants
Created Comparable object. It worked that way. Thanks :)
psvm
A: 

Another good way of doing this that is a bit more flexible if there is more than one property of an object that you may wish to sort by is to use Guava's Ordering class with its onResultOf(Function) option. This is ideally suited for sorting by properties since a Function can be used to retrieve and return a specific property of an object. For a simple example, imagine a class Person with String getFirstName() and String getLastName() methods.

List<Person> people = ...;
Collections.sort(people, Ordering.natural().onResultOf(
    new Function<Person, String>() {
      public String apply(Person from) {
        return from.getFirstName();
      }
    }));

The above will sort the list by first name.

To make it read nicer, you may want to define the functions you might want to use as public static final fields on the Person class. Then you could sort by last name like this:

Collections.sort(people, Ordering.natural().onResultOf(Person.GET_LAST_NAME));

As a fun aside note, this should all be a lot easier in Java 7 with lambda expressions and method references. As the plan stands now, you'll probably be able to write something like this without having to define any clumsy anonymous inner classes or static final fields:

people.sort(Ordering.natural().onResultOf(Person#getLastName()));

There could even be something like this:

people.sortBy(Person#getLastName());
ColinD