ArrayList 对象排序实例

简介: ArrayList 对象排序实例
import java.util.ArrayList;   
import java.util.Collection;   
import java.util.Collections;   
import java.util.Comparator;   
  
  
public class SortTwo implements Comparator {   
//排序字段   
private String sort1;   
//排序方式   
private int state;   
public SortTwo(int state){   
this.state=state;   
}   
public SortTwo(){   
  
}   
public int SortUp(Object o1,Object o2){   
Student stu=(Student) o1;   
Student stu1=(Student) o2;   
if(sort1.equals("name")){   
if(stu.getName().compareTo(stu1.getName())>1){   
return 1;   
} else if(stu.getName().compareTo(stu1.getName())<1){   
return -1;   
}else{   
return 0;   
}   
}   
if(sort1.equals("age")){   
if(stu.getAge().compareTo(stu1.getAge())>1){   
return 1;   
} else if(stu.getAge().compareTo(stu1.getAge())<1){   
return -1;   
}else{   
return 0;   
}   
}   
return 0;   
}   
public int SortDOWN(Object o1,Object o2){   
Student stu=(Student) o1;   
Student stu1=(Student) o2;   
if(sort1.equals("name")){   
if(stu.getName().compareTo(stu1.getName())>1){   
return -1;   
} else if(stu.getName().compareTo(stu1.getName())<1){   
return 1;   
}else{   
return 0;   
}   
}   
if(sort1.equals("age")){   
if(stu.getAge().compareTo(stu1.getAge())>1){   
return -1;   
} else if(stu.getAge().compareTo(stu1.getAge())<1){   
return 1;   
}else{   
return 0;   
}   
}   
return 0;   
}   
public int compare(Object o1, Object o2) {   
  
if(this.state==1){   
return SortUp(o1, o2);   
}else{   
return SortDOWN(o1, o2);   
}   
}   
  
/**  
* @param args  
*/  
public static void main(String[] args) {   
// TODO Auto-generated method stub   
Student stu=new Student();   
stu.setName("123");   
stu.setAge("12");   
Student stu1=new Student();   
stu1.setName("234");   
stu1.setAge("23");   
ArrayList<Student>list=new ArrayList<Student>();   
list.add(stu);   
list.add(stu1);   
SortTwo t=new SortTwo(1);   
t.sort1="age";   
Collections.sort(list,t);   
for(Student st : list){   
System.out.println(st.getName() +"   "+st.getAge());   
}   
}   
  
}   
相关文章
|
5天前
|
存储 安全 Java
32.C#:ArrayList集合
32.C#:ArrayList集合
20 1
|
5月前
|
C#
C# 集合(ArrayList)的方法和使用
C# 集合(ArrayList)的方法和使用
|
7月前
|
Java
Map集合详解及Collections方法和Arrays方法
Map集合详解及Collections方法和Arrays方法
40 0
|
10月前
|
存储 算法
|
10月前
|
存储 安全 C#
C#里面的不同集合(数组、ArrayList集合、List泛型)
在内存中连续存储,因此可以快速而容易地从头到尾遍历元素,可以快速地修改元素
|
10月前
|
安全 C# 索引
C# 泛型集合和非泛型集合(List ArrayLIst)
C# 泛型集合和非泛型集合(List ArrayLIst)
64 0
集合排序-List集合
在Collections下有一个方法,sort()方法,不仅是数值,其他类型也有默认的排序方法
使用两个ArrayList集合实现简单的map
使用两个ArrayList集合实现简单的map
|
缓存 安全 算法
ArrayList 可以完全替代数组吗?
在前面的文章里],我们学习了很多数据结构与算法思想。在实际的业务开发中,往往不需要我们手写数据结构,而是直接使用标准库的数据结构 / 容器类。 在后续的文章里,我们将以 Java 语言为例,分析从 ArrayList 到 LinkedHashMap 等一系列标准库容器类,最后再有一篇总结回顾,请关注。
109 0
|
存储
ArrayList的retainAll()方法使用
retainAll()方法:list1.retainAll(list2),即list1调用retainAll()方法得到list1和list2的交集并存储在list1中,这个方法的返回值是boolean型,true代表方法执行成功。 @Test public void test1() { ArrayList arrayList1 = new ArrayList(); arrayList1.add(123); arrayList1.add.
203 0