第八十七课.super和this的使用总结

本文深入探讨了Java中super()和this()的使用方法及其区别。super()用于调用父类构造方法,this()则用于调用同一类中的其他构造方法。两者都不能在静态环境中使用,且在同一构造方法中不能共存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

上3节课说过super()可以显示调用父类构造方法,这节课的this()是可以显式调用本类的构造方法。

super()和this ()不能共存,否则编译时会报异常。Constructor call must be the first statement in a constructor换句话说就是super()和this ()都必须在构造方法的第一行。

 

this(有参数/无参数) 用于调用本类相应的构造函数

super(有参数/无参数) 用于调用父类相应的构造函数

而且在构造函数中,调用必须写在构造函数定义的第一行,不能在构造函数的后面使用。

一个构造函数定义中不能同时包括this调用和super调用,如果想同时包括的话,可以在一每构造器中使用一个(第一行只有一个···两个同时存在第二行的那个就无效报错了)

 

总结super和this的异同:

  1. super(参数):调用基类中的某一个构造函数(应该为构造函数中的第一条语句)
  2. this(参数):调用本类中另一种形成的构造函数(应该为构造函数中的第一条语句)
  3. super: 它引用当前对象的直接父类中的成员(用来访问直接父类中被隐藏的父类中成员数据或函数,基类与派生类中有相同成员定义时如:super.变量名    super.成员函数据名(实参)
  4. this:它代表当前对象名(在程序中易产生二义性之处,应使用this来指明当前对象;如果函数的形参与类中的成员数据同名,这时需用this来指明成员变量名)
  5. 调用super()必须写在子类构造方法的第一行,否则编译不通过。每个子类构造方法的第一条语句,都是隐含地调用super(),如果父类没有这种形式的构造函数,那么在编译的时候就会报错。
  6. super()和this()类似,区别是,super()从子类中调用父类的构造方法,this()在同一类内调用其它方法。
  7. super()和this()均需放在构造方法内第一行。
  8. 尽管可以用this调用一个构造器,但却不能调用两个。
  9. this和super不能同时出现在一个构造函数里面,因为this必然会调用其它的构造函数,其它的构造函数必然也会有super语句的存在,所以在同一个构造函数里面有相同的语句,就失去了语句的意义,编译器也不会通过。
  10. this()和super()都指的是对象,所以,均不可以在static环境中使用。包括:static变量,static方法,static语句块。
  11. 从本质上讲,this是一个指向本对象的指针, 然而super是一个Java关键字。
zf ) ; Student[] students = new Student[10]; // 初始化10个学生对象 students[0] = new Student("001", "张三", 90.5f); students[1] = new Student("002", "李四", 85.0f); students[2] = new Student("003", "王五", 92.5f); students[3] = new Student("004", "赵六", 88.0f); students[4] = new Student("005", "钱七", 95.5f); students[5] = new Student("006", "孙八", 89.0f); students[6] = new Student("007", "周九", 91.5f); students[7] = new Student("008", "吴十", 87.5f); students[8] = new Student("009", "郑一", 93.0f); students[9] = new Student("010", "冯二", 86.5f); // 对数组进行排序 for (int i = 0; i < students.length; i++) { for (int j = i + 1; j < students.length; j++) { if (students[i].getzf() < students[j].getzf()) { Student temp = students[i]; students[i] = students[j]; students[j] = temp; } } } // 创建 Vector 对象并将排序后的学生对象存入 Vector<Student> vector = new Vector<Student>(); for (int i = 0; i < students.length; i++) { vector.add(students[i]); } // 创建 ArrayList 对象并将排序后的学生对象存入 ArrayList<Student> arrayList = new ArrayList<Student>(); for (int i = 0; i < students.length; i++) { arrayList.add(students[i]); } // 创建 Hashtable 对象并将排序后的学生对象存入 Hashtable<String, Student> hashtable = new Hashtable<String, Student>(); for (int i = 0; i < students.length; i++) { hashtable.put(students[i].getxh(), students[i]); } // 遍历 vector 中的学生对象并输出信息 System.out.println("Vector 中的学生对象:"); for (int i = 0; i < vector.size(); i++) { Student student = vector.get(i); System.out.println(student.toString()); } // 遍历 arrayList 中的学生对象并输出信息 System.out.println("ArrayList 中的学生对象:"); Iterator<Student> arrayIterator = arrayList.iterator(); while (arrayIterator.hasNext()) { Student student = arrayIterator.next(); System.out.println(student.toString()); } // 遍历 hashtable 中的学生对象并输出信息 System.out.println("HashTable 中的学生对象:"); Enumeration<Student> hashEnumeration = hashtable.elements(); while (hashEnumeration.hasMoreElements()) { Student student = hashEnumeration.nextElement(); System.out.println(student.toString()); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xuenixiang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值