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
HashMap与LinkedHashMap类型集合
【8月更文挑战第4天】`HashMap` 是基于哈希表实现的键值对存储结构,提供快速的查找、插入和删除操作,但不保证元素顺序。适用于不关心顺序且需高效操作的场景。 `LinkedHashMap` 继承自 `HashMap`,保持了元素的插入或访问顺序。适合需要按特定顺序遍历元素的应用,如按添加顺序显示购物车商品。其操作效率与 `HashMap` 相近。
|
8月前
|
存储 安全 Java
32.C#:ArrayList集合
32.C#:ArrayList集合
45 1
C# 集合(ArrayList)的方法和使用
C# 集合(ArrayList)的方法和使用
|
算法
ArrayList类
ArrayList类
57 0
|
Java
Map集合详解及Collections方法和Arrays方法
Map集合详解及Collections方法和Arrays方法
66 0
|
存储 算法
|
存储 安全 C#
C#里面的不同集合(数组、ArrayList集合、List泛型)
在内存中连续存储,因此可以快速而容易地从头到尾遍历元素,可以快速地修改元素
|
存储 程序员 索引
List集合和其子类ArrayList、LinkedList
List集合和其子类ArrayList、LinkedList
148 1
|
缓存 安全 算法
ArrayList 可以完全替代数组吗?
在前面的文章里],我们学习了很多数据结构与算法思想。在实际的业务开发中,往往不需要我们手写数据结构,而是直接使用标准库的数据结构 / 容器类。 在后续的文章里,我们将以 Java 语言为例,分析从 ArrayList 到 LinkedHashMap 等一系列标准库容器类,最后再有一篇总结回顾,请关注。
140 0
|
存储 C#
简单数据结构类——Arraylist
简单数据结构类——Arraylist
111 0