Flask接口签名sign原理与实例代码浅析
313
2022-11-04
关于java关键字this和super的区别和理解
this:
this理解为:当前对象 或 当前正在创建的对象
可以调用的结构:属性、方法;构造器
this调用属性、方法:
先了解一下形参:
形参的意义就是给属性赋值,我们是要给同名的属性赋值,这时候我们就把形参名和属性的名字写成一样,这样我们就知道我们传入的形参就是要给我们同名的属性去赋值的.
在类的方法中,我们可以使用"this.属性"或"this.方法"的方式,调用当前对象属性或方法。但是,
通常情况下,我们都择省略"this."。特殊情况下,如果方法的形参和类的属性同名时,我们必须显式的使用"this.变量"的方式,表明此变量是属性,而非形参。
举例:我们声明一个类叫鞋类,给它提供私有的属性和get/set方法和构造器:
//声明一个鞋类
public class shoes {
//鞋的属性
private String name;//鞋名
private int id;//编号
//无参构造器
public shoes() {
}
//有参构造器:
public shoes(String name, int id) {
// name = name;没加this
this.name = name;
// id = id; 没加this
this.id = id;
}
//声明两个方法
public void show(){
System.out.println("展示~~");
sale();//show方法中调sale方法
// this.sale();//this可省略
}
public void sale(){
System.out.println("售卖~~");
}
//get/set方法:
public String getName() {
return name;
}
public void setName(String name) {
//name = name;没加this
this.name = name;
}
public void setId(int id) {
//id = id;没加this
this.id = id;
}
public int getId() {
return id;
}
}
//测试
class test {
public static void main(String[] args) {
//我们先实例化鞋类的对象来调它的属性
shoes s = new shoes();
s.setName("nike");//这里的"nike"就是传入的形参
System.out.println(s.getName());
//我们获取鞋名的时候,获取不到,意思就是形参的值又赋给了形参,代表没有给鞋的属性赋上值
//这个时候控制台会输出传入的形参数据类型的默认值,明显不是我们想看到的结果
s.setId(1);
System.out.println(s.getId());//鞋的id类似的也会出现同样的情况
//"this.方法"举例:
s.show();
/*我们先调的是show自己的方法体,然后在show方法中调了sale方法
意思是s这个对象调了show方法,我们就用调show方法的这个对象s来调sale方法,
其实在sale();前面也省略了this关键字,表示当前对象(就是调show方法的对象)调的sale方法*/
System.out.println("------------------------分割线--------------------");
shoehttp://s s1 = new shoes("李宁",2);//我们new的有参数的对象给它赋初值之后
System.out.println(s1.getName());
System.out.println(s1.getId());//如果没有加this,结果还是和没有获取到鞋名和编号
}
}
先来看没有加this关键字的情况:
结果:
然后我们给鞋属性加上this关键字:
控制台输出的就是我们给鞋设置的名字和编号:
在类的构造器中,我们可以使用"this.属性"或"this.方法"的方式,调用当前正在创建的对象属性或方法。但是,通常情况下,我们都择省略"this."。特殊情况下,如果构造器的形参和类的属性同名时,我们必须显式的使用"this.变量"的方式,表明此变量是属性,而非形参。
同样的我们的构造器也是一样:如果有参构造器没有加给属性加this关键字:控制台输出结果也和上面一样
加上之后:
"this.方法"举例:我们声明两个方法show和sale方法来举例体会一下this的作用:代码参照上面:
s.show();的结果:
this调用构造器:
① 我们在类的构造器中,可以显式的使用"this(形参列表)"方式,调用本类中指定的其他构造器
② 构造器中不能通过"this(形参列表)“方式调用自己
③ 如果一个类中有n个构造器,则最多有 n - 1构造器中使用了"this(形参列表)”
④ 规定:"this(形参列表)“必须声明在当前构造器的首行
⑤ 构造器内部,最多IiCRRqNke只能声明一个"this(形参列表)”,用来调用其他的构造器
举例:我们还是写一个Shoes类 提供私有属性和get/set方法并提供三个构造器:
public class Shoes {
//属性
private String name;//鞋名
private int id;//编号
//get/set方法:
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
//构造器1
public Shoes() {
System.out.println("构造器1");
}
//构造器2
public Shoes(int id){
this();//调构造器1
System.IiCRRqNkeout.println("构造器2");
this.id = id;
}
//构造器3
public Shoes(String name, int id) {
//通过调用构造器来执行其他构造器中的代码
this(id);//调构造器2
// this.id = id;//交给构造器2来执行
this.name = name;
//我们如果需要使用到其他构造器中的代码就可以使用"this.构造器"的方式
//这里只是为了举例我们只写了一行输出语句,真正实际中我们写的代码多了,调用构造器的方法的优势就体现出来了
//这样我们可以减少代码的冗余,提高程序执行效率
}
}
class test{
public static void main(String[] args) {
//用构造器3来实例化对象,我们在构造器3中没有把参数id赋给当前对象
//但是通过调构造器2,构造器2中执行了 this.id = id;把id赋给了当前对象的属性
//所以我们才可以得到当前对象s3的id
Shoes s3 = new Shoes("adidas",2021);
System.out.println(s3.getId());
}
}
运行结果:
super:
super 关键字可以理解为:父类的
可以用来调用的结构:
属性、方法、构造器
super调用属性、方法:
我们可以在子类的方法或构造器中。通过使用"super.属性"或"super.方法"的方式,显式的调用父类中声明的属性或方法。但是,通常情况下,我们习惯省略"super."
①特殊情况:IiCRRqNke当子类和父类中定义了同名的属性时,我们要想在子类中调用父类中声明的属性,则必须显式的使用"super.属性"的方式,表明调用的是父类中声明的属性。
② 特殊情况:当子类重写了父类中的方法以后,我们想在子类的方法中调用父类中被重写的方法时,则必须显式的使用"super.方法"的方式,表明调用的是父类中被重写的方法(也就是父类中原本的方法)。
举例两种特殊情况:在子类的方法中调用父类中同名的属性和方法:
创建一个人类,一个学生类,学生类继承人类,和一个测试类
//人类
public class Person {
//属性
String name = "普通人";//姓名
int id = 1234;//身份证号
//方法
public void learn(){
System.out.println("人要学习");
}
}
//学生类
public class Student extends Person {
//声明了与父类的同名属性
String name = "哈利波特";//姓名
int id = 9527;//学号
@Override//子类重写父类的方法
public void learn() {
System.out.println("学生要努力学习");
super.learn();//调父类中原本的方法
System.out.println("姓名:"+name);//子类自己的属性
System.out.println("学号:"+id);
System.out.println("姓名:"+super.name);//父类中声明的属性
System.out.println("身份证号:"+super.id);
}
}
//测试类
public class Test {
public static void main(String[] args) {
//实例化子类对象
Student student = new Student();
//调子类中重写父类的方法
student.learn();
}
}
输出结果:
super调用构造器:
我们可以在子类的构造器中显式的使用"super(形参列表)"的方式,调用父类中声明的指定的构造器
注意:
"super(形参列表)"的使用,必须声明在子类构造器的首行!我们在类的构造器中,针对于"this(形参列表)"或"super(形参列表)"只能二者取其一,不能同时出现在构造器的首行,没显式的声明"this(形参列表)“或"super(形参列表)”,则默认调用的是父类中空参的构造器:super()在类的多个构造器中,至少一个类的构造器中使用了"super(形参列表)",调用父类中的构造器
举例:还是用上面的例子,我们在人类和学生类中添加构造器:
public class Person {
//属性
String name = "普通人";//姓名
int id = 1234;//身份证号
//构造器
public Person() {
}
public Person(String name, int id) {
this.name = name;
this.id = id;
}
//方法
public void learn(){
System.out.println("人要学习");
}
}
public class Student extends Person {
//声明了与父类的同名属性
String name = "哈利波特";//姓名
int id = 9527;//学号
//构造器1
public Student(String name, int id) {
this.name = name;
this.id = id;
}
//构造器2
public Student(String name, int id, String name1, int id1) {
super(name, id);//调用父类已有的构造器
this.name = name1;
this.id = id1;
}
@Override//子类重写父类的方法
public void learn() {
System.out.println("学生要努力学习");
super.learn();//调父类中原本的方法
System.out.println("姓名:"+name);//子类自己的属性
System.out.println("学号:"+id);
System.out.println("姓名:"+super.name);//父类中声明的属性
System.out.println("身份证号:"+super.id);
}
}
在子类构造器2中调用父类已有的有参构造器:
然后测试:实例化学生类的对象并给属性赋值,调learn方法:http://
public class Test {
public static void main(String[] args) {
Student student = new Student("人",8888,"学生",2021);
student.learn();
}
}
输出结果:
this与super的区别总结:
①代表事物不同
this表示当前所属函数的调用者对象
super表示调用父类的结构(属性,方法,构造器)
②使用前提不同
super必须要有继承关系才能使用
this不需要继承关系也能使用
③调用的构造器不同
super:调用父类的构造器
this:调用当前类(本类)的构造器
说明:
在栈空间中存放的是对象的引用也就是对象名指向堆空间中new的对象,在堆空间中子类和父类的属性都会有,this和super都可以通过栈空间的引用指向堆空间来调用具体的属性.
继续加油~~冲冲冲! ! !
总结
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~