详解JAVA使用Comparator接口实现自定义排序
这篇文章主要介绍了JAVA使用Comparator接口实现自定义排序,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧1、原则
comparator接口可以实现自定义排序,实现comparator接口时,要重写compare方法:
int compare(object o1, object o2) 返回一个基本类型的整型
如果要按照升序排序,则o1 小于o2,返回-1(负数),相等返回0,01大于02返回1(正数)
如果要按照降序排序,则o1 小于o2,返回1(正数),相等返回0,01大于02返回-1(负数)
import java.util.arraylist;
import java.util.comparator;
import java.util.list;
public class usercomparator implements comparator < user > {
public static void main( string[] args ) {
list < user > users = new arraylist < user >();
users.add( new user( 10, "a" ) );
users.add( new user( 11, "d" ) );
users.add( new user( 15, "s" ) );
users.add( new user( 6, "x" ) );
users.add( new user( 17, "a" ) );
users.add( new user( 17, "b" ) );
users.add( new user( 17, "c" ) );
users.add( new user( 17, "d" ) );
usercomparator comparator = new usercomparator();
users.sort( comparator );
// 也可以使用:collections.sort( users, comparator );
for ( user u : users ) {
system.out.println( u );
}
}
@override
public int compare( user u1, user u2 ) {
if ( u1.equals( u2 ) ) {
return 0;
}
else if ( u1.getage() < u2.getage() ) {
return 1;
}
else if ( u1.getage() == u2.getage() ) {
int f = u1.getname().compareto( u2.getname() );
if ( f < 0 ) {
return -1;
}
return 0;
}
else {
return -1;
}
}
}
class user {
private int age;
private string name;
public user() {
}
public user( int age, string name ) {
this.age = age;
this.name = name;
}
public int getage() {
return age;
}
public void setage( int age ) {
this.age = age;
}
public string getname() {
return name;
}
public void setname( string name ) {
this.name = name;
}
@override
public string tostring() {
return "user ";
}
}
user
user
user
user
user
user
user
user
以上所述是小编给大家介绍的java使用comparator接口实现自定义排序详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对CodeAE代码之家网站的支持!
原文链接:https://www.cnblogs.com/mengzj233/p/9816289.html
http://www.zzvips.com/article/178093.html
页:
[1]