必备知识点:
1.println(对象)则直接调用了对象所属类中重写的toString方法,如果没有重写则直接调用Object中的原始toString方法:
//@Override 的作用是:
//如果想重写父类的方法,
//比如toString()方法的话,
//在方法前面加上@Override
//系统可以帮你检查方法的正确性。
//重写toString方法,没有形参
@Override
public String toString() {
return "no="+this.no+"&name="+this.name;
}
2.重写equals方法:
//重写equals方法,有形参
@Override
public boolean equals(Object o) {
if (o==null) return false;//如果o根本不存在
else {//存在
boolean result=false;
if (o instanceof Student) {//判断是否为子类或本类对象
Student otherstu=(Student)o;//是则转化为Student类
if (this.no==otherstu.no)//比较no
result=true;
}
return result;
}
}
3.重写compareTo方法:()
//java中所有类的父类都是Object类,Student的父类也是Object
//所以在Student类中可以不用声明extend,Object里面的方法可以直接被Student重写
//equals和toString方法
//但是因为compareto方法是接口comparable的所以要先声明接口comparable再重写他的compareTo方法
//实现comparable接口中的compareto方法
@Override
public int compareTo(Object arg0) {
//第一步先转换为Student类型
Student otherstu=(Student)arg0;
if (this.no<otherstu.no)return -1;
else if (this.no>otherstu.no)return 1;
else return 0;
//小的往上走位置-1,大的往下走+1,相等的位置保持不变
//按照首字母降序排列的话就将1和-1倒过来
}
题目:
要求:根据Main类中main方法中的代码,设计满足要求的Student(学生)类:1)包含属性:int no(学号)、String name(姓名);2)满足Main类中main方法代码的说明要求。 Main类中main方法代码的说明:1)首先,从键盘接收形如“3 cuizhenyu 2 tiangang 1 dingchangqing 4 zhangfeng”的字符串,该字符串中包含了4个学生的学号和姓名(各学生以及学生的学号和姓名之间都用一个空格分隔,姓名中只包含英文字母),然后将该字符串内容中的前3个学生的学号及其姓名放到到Student数组stus中;2)将stus中的3个Student放入到HashSet stuSet中(注意:如果学生的学号相同,则认为是相同对象,不放入stuSet中);3)将第4个学生对象放入到stuSet中,如果第4个学生对象的学号与stuSet中已有学生对象的学号相同则不能放入。然后,打印出当前stuSet中学生对象的个数;4)用Arrays.sort方法对数组stus按照学生姓名的字母顺序排序(先比较首字母,首字母相同的比较第二个字母,以此类推),输出排序后的stus中3个学生对象的内容,每个学生对象的输出格式为“no=XX&name=YY”。
main类代码:
import java.util.Arrays;
import java.util.HashSet;
import java.util.Scanner;
import java.lang.*;
public class Main{
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
Student[] stus = new Student[3];
for(int i=0;i<3;i++){
int no = scan.nextInt();
String name = scan.next();
Student s = new Student(no,name);
stus[i] =s;
}
//将stus中的3个学生对象,放入到HashSet中
HashSet<Student> stuSet = new HashSet<Student>();
for(Student s: stus){//s相当于i
stuSet.add(s);
}
//要放入的第4个Student
Student fourth = new Student(scan.nextInt(),scan.next());
stuSet.add(fourth);//如果fourth的学号(no)与stuSet中的已有学生的no重复则无法放入
System.out.println(stuSet.size());//第一次输出——4
Arrays.sort(stus);//对stus中的3个原有对象,按照姓名首字符有小到大排序
//前提是必须实现了comparable接口
for(int i=0;i<stus.length;i++){//排序后的输出
System.out.println(stus[i]);//输出的格式为:no=XX&name=YY
}
scan.close();
}
}
答案:
//java中所有类的父类都是Object类,Student的父类也是Object
//所以在Student类中可以不用声明extend,Object里面的方法可以直接被Student重写
//equals和toString方法
//但是因为compareto方法是接口comparable的所以要先声明接口comparable再重写他的compareTo方法
class Student implements Comparable{
//接口一般首字母大写如Comparable和Collection List
private int no;
private String name;
public Student(int no, String name) {
this.name=name;
this.no=no;
}
//toString和equals方法都是object类本来就有的
//重写toString方法,没有形参
@Override
public String toString() {
return "no="+this.no+"&name="+this.name;
}
//重写equals方法,有形参
@Override
public boolean equals(Object o) {
if (o==null) return false;//如果o根本不存在
else {//存在
boolean result=false;
if (o instanceof Student) {//判断是否为子类或本类对象
Student otherstu=(Student)o;//是则转化为Student类
if (this.no==otherstu.no)//比较no
result=true;
}
return result;
}
}
//实现comparable接口中的compareto方法
@Override
//@Override 的作用是:
//如果想重写父类的方法,
//比如toString()方法的话,
//在方法前面加上@Override
//系统可以帮你检查方法的正确性。
public int compareTo(Object arg0) {
//第一步先转换为Student类型
Student otherstu=(Student)arg0;
if (this.no<otherstu.no)return -1;
else if (this.no>otherstu.no)return 1;
else return 0;
//小的往上走位置-1,大的往下走+1,相等的位置保持不变
//按照首字母降序排列的话就将1和-1倒过来
}
}
遇到的问题
当在环境中运行程序发现出现错误提示:
错误: 在类中找不到 main 方法, 请将 main 方法定义为:public static void main(String[] args)否则 JavaFX 应用程序类必须扩展javafx.ap
解决详见https://blog.csdn.net/liu1340308350/article/details/80746671