Java——集合IO综合应用
2012-09-23 11:17
337 查看
/*
有五个学生,每个学生有3门课的成绩,
从键盘输入以上数据(包括姓名,三门课成绩),
输入的格式:如:zhagnsan,30,40,60计算出总成绩,
并把学生的信息和计算出的总分数高低顺序存放在磁盘文件"stud.txt"中。
1,描述学生对象。
2,定义一个可操作学生对象的工具类。
思想:
1,通过获取键盘录入一行数据,并将该行中的信息取出封装成学生对象。
2,因为学生有很多,那么就需要存储,使用到集合。因为要对学生的总分排序。
所以可以使用TreeSet。
3,将集合的信息写入到一个文件中。
*/
import java.io.*;
import java.util.*;
class Student implements Comparable<Student>//继承Comparable接口实现compareTo方法
{
private String name;
private int ma,cn,en;
private int sum;
Student(String name,int ma,int cn,int en)//定义类
{
this.name = name;
this.ma = ma;
this.cn = cn;
this.en = en;
sum = ma + cn + en;
}
public int compareTo(Student s)//将类对象作为参数进行自定义的比较
{
int num = new Integer(this.sum).compareTo(new Integer(s.sum));
if(num==0)
return this.name.compareTo(s.name);
return num;
}
public String getName()//取出name方法
{
return name;
}
public int getSum()//取出sum方法
{
return sum;
}
public int hashCode()//自定义hashCode返回值。
{
return name.hashCode()+sum*78;
}
public boolean equals(Object obj)//重写equals
{
if(!(obj instanceof Student))
throw new ClassCastException("类型不匹配");
Student s = (Student)obj;
return this.name.equals(s.name) && this.sum==s.sum;
}
public String toString()
{
return "student["+name+", "+ma+", "+cn+", "+en+"]";
}
}
class StudentInfoTool
{
public static Set<Student> getStudents()throws IOException
{
return getStudents(null);
}
public static Set<Student> getStudents(Comparator<Student> cmp)throws IOException//将Student存储到集合并进行排序
{
BufferedReader bufr =
new BufferedReader(new InputStreamReader(System.in));//从键盘读取数据到BufferedReader
String line = null;
Set<Student> stus = null;
if(cmp==null)
stus = new TreeSet<Student>();//TreeSet排序按照Comparator定义的比较方法
else
stus = new TreeSet<Student>(cmp);
while((line=bufr.readLine())!=null)
{
if("over".equals(line))
break;
String[] info = line.split(",");
Student stu = new Student(info[0],Integer.parseInt(info[1]),
Integer.parseInt(info[2]),
Integer.parseInt(info[3]));
stus.add(stu);
}
bufr.close();
return stus;
}
public static void write2File(Set<Student> stus)throws IOException//
{
BufferedWriter bufw = new BufferedWriter(new FileWriter("stuinfo.txt"));//当前路径创建stuinfo.txt文件包装缓冲
for(Student stu : stus)//遍历stus集合内容写入文件stuinfo.txt
{
bufw.write(stu.toString()+"\t");
bufw.write(stu.getSum()+"");
bufw.newLine();
bufw.flush();//刷新缓冲
}
bufw.close();//关闭流资源
}
}
class StudentInfoTest
{
public static void main(String[] args) throws IOException
{
Comparator<Student> cmp = Collections.reverseOrder();
Set<Student> stus = StudentInfoTool.getStudents(cmp);
StudentInfoTool.write2File(stus);
}
}
有五个学生,每个学生有3门课的成绩,
从键盘输入以上数据(包括姓名,三门课成绩),
输入的格式:如:zhagnsan,30,40,60计算出总成绩,
并把学生的信息和计算出的总分数高低顺序存放在磁盘文件"stud.txt"中。
1,描述学生对象。
2,定义一个可操作学生对象的工具类。
思想:
1,通过获取键盘录入一行数据,并将该行中的信息取出封装成学生对象。
2,因为学生有很多,那么就需要存储,使用到集合。因为要对学生的总分排序。
所以可以使用TreeSet。
3,将集合的信息写入到一个文件中。
*/
import java.io.*;
import java.util.*;
class Student implements Comparable<Student>//继承Comparable接口实现compareTo方法
{
private String name;
private int ma,cn,en;
private int sum;
Student(String name,int ma,int cn,int en)//定义类
{
this.name = name;
this.ma = ma;
this.cn = cn;
this.en = en;
sum = ma + cn + en;
}
public int compareTo(Student s)//将类对象作为参数进行自定义的比较
{
int num = new Integer(this.sum).compareTo(new Integer(s.sum));
if(num==0)
return this.name.compareTo(s.name);
return num;
}
public String getName()//取出name方法
{
return name;
}
public int getSum()//取出sum方法
{
return sum;
}
public int hashCode()//自定义hashCode返回值。
{
return name.hashCode()+sum*78;
}
public boolean equals(Object obj)//重写equals
{
if(!(obj instanceof Student))
throw new ClassCastException("类型不匹配");
Student s = (Student)obj;
return this.name.equals(s.name) && this.sum==s.sum;
}
public String toString()
{
return "student["+name+", "+ma+", "+cn+", "+en+"]";
}
}
class StudentInfoTool
{
public static Set<Student> getStudents()throws IOException
{
return getStudents(null);
}
public static Set<Student> getStudents(Comparator<Student> cmp)throws IOException//将Student存储到集合并进行排序
{
BufferedReader bufr =
new BufferedReader(new InputStreamReader(System.in));//从键盘读取数据到BufferedReader
String line = null;
Set<Student> stus = null;
if(cmp==null)
stus = new TreeSet<Student>();//TreeSet排序按照Comparator定义的比较方法
else
stus = new TreeSet<Student>(cmp);
while((line=bufr.readLine())!=null)
{
if("over".equals(line))
break;
String[] info = line.split(",");
Student stu = new Student(info[0],Integer.parseInt(info[1]),
Integer.parseInt(info[2]),
Integer.parseInt(info[3]));
stus.add(stu);
}
bufr.close();
return stus;
}
public static void write2File(Set<Student> stus)throws IOException//
{
BufferedWriter bufw = new BufferedWriter(new FileWriter("stuinfo.txt"));//当前路径创建stuinfo.txt文件包装缓冲
for(Student stu : stus)//遍历stus集合内容写入文件stuinfo.txt
{
bufw.write(stu.toString()+"\t");
bufw.write(stu.getSum()+"");
bufw.newLine();
bufw.flush();//刷新缓冲
}
bufw.close();//关闭流资源
}
}
class StudentInfoTest
{
public static void main(String[] args) throws IOException
{
Comparator<Student> cmp = Collections.reverseOrder();
Set<Student> stus = StudentInfoTool.getStudents(cmp);
StudentInfoTool.write2File(stus);
}
}
相关文章推荐
- java基础的综合应用(类的应用,文本拷贝,IO流,数组,集合,文件文件夹的创建)
- Java基础---Java---基础加强---内省的简单运用、注解的定义与反射调用、 自定义注解及其应用、泛型及泛型的高级应用、泛型集合的综合
- Java基础---Java---基础加强---内省的简单运用、注解的定义与反射调用、 自定义注解及其应用、泛型及泛型的高级应用、泛型集合的综合
- 黑马程序员——JAVA基础--- 集合IO综合练习排序问题
- java IO应用
- Silverlight:双向绑定综合应用-自动更新集合汇总字段
- java中集合类list set map三者的区别和应用场合
- Java的IO结构图和集合结构图
- 【Android每日一讲】2012.11.28 快速地搜索手机文件引擎 - Java IO的应用
- java线程实现和集合类综合问题
- Java多线程与并发库高级应用-同步集合
- Java IO笔记(2)典型应用
- Silverlight:双向绑定综合应用-自动更新集合汇总字段
- java-IO常用集合API
- java多线程之线程并发库同步集合类的应用
- 38 泛型的通配符扩展应用39 泛型集合的综合应用案例
- java程序设计之集合中的泛型的应用
- Java IO:BIO和NIO差别及各自应用场景
- 集合List与面向对象编程综合应用
- 【java基础:集合与IO】Properties集合与IO流相结合进行数据读取和存储的demostration