我编写了这样的代码,它从一个文件夹中的文本文件(150 个文本文件)创建 150 个员工对象并将其存储在一个集合中。
这些文本文件包含员工的身份证、姓名和年龄。
我的问题是我想对这 150 名员工的 ID、姓名和年龄进行排序。我应该如何编写它。我应该实现比较器还是可比较的接口?并实施它。请指导我
代码如下:
package com.fulcrum.emp;
import java.io.File;
import java.io.FileNotFoundException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.Scanner;
public class TestingColections {
public static void main(String[] args) {
File folder = new File("D:\\employee files");
File[] listOfFiles = folder.listFiles();
ArrayList<Employee> emp= new ArrayList<Employee>();;
int id = 0;
String name = null;
int age = 0;
for (File file : listOfFiles) {
try {
Scanner scanner = new Scanner(file);
String tokens = "";
String[] newtokens = null;
while (scanner.hasNext()) {
tokens = tokens.concat(scanner.nextLine()).concat(" ");
tokens = tokens.replace("=", "|");
newtokens = tokens.split("[|\\s]");
}
id = Integer.parseInt(newtokens[1]);
name = (newtokens[3] + " " + newtokens[4]);
age = Integer.parseInt(newtokens[6]);
emp.add(new Employee(id, name, age));
} catch (FileNotFoundException e) {
e.printStackTrace();
}
}
for(int i=0;i<emp.size();i++)
{
System.out.println(emp.get(i));
}
}
}