当然这儿说的第一个是培训后.不包括以前的.
学习了Properties类和他的一些方法尹老师就叫我们自己回去写一下怎样读取Properties文件里面的值再根据年龄排序.和夏天讨论了很久的.当时也想到用TreeMap但考虑到不能重复Key年龄相同的就要被覆盖.突然记起看孙鑫老师的视频教程里面有讲集合类自己又去找到以前自己边看边写的代码,用比较器实现.只是复杂了点贴一下代码:
import java.util.*;
import java.io.*;
class Student implements Comparable
{
int age;
String name;
public Student(int age, String name)
{
this.age = age;
this.name = name;
}
public int compareTo(Object o)
{
Student s = (Student)o;
return age > s.age ? 1:(age == s.age ? 0 : -1);
}
public String toString()
{
return "name=" + name +", age=" + age;
}
}
public class Test
{
public static void printElements(Collection c)
{
Iterator it=c.iterator();
while(it.hasNext())
{
System.out.println(it.next());
}
}
public static void main(String[] args)
{
Properties properties = new Properties();
try
{
properties.load(new FileInputStream("class3.properties"));
//Student student;
List list=new ArrayList();
Enumeration emu = properties.propertyNames();
while (emu.hasMoreElements())
{
String sname = (String)emu.nextElement();
int sage = Integer.parseInt(properties.getProperty(sname));
Student student = new Student(sage, sname);
list.add(student);
}
Collections.sort(list);
printElements(list);
}
catch (IOException e)
{
e.printStackTrace();
}
}
}
虽然后面一直有的TreeMap来装的Properties里面的内容但TreeMap键不能重复一直是个问题的.感觉用个学生类来装属性值要好得多.只是才第一周JAVA基础方面的知识都还没讲很多同学基础差不理解的.还是用TreeMap