您现在的位置是:主页 > news > 一个公司可以做几个网站备案/广告的六种广告形式
一个公司可以做几个网站备案/广告的六种广告形式
admin2025/5/21 15:52:52【news】
简介一个公司可以做几个网站备案,广告的六种广告形式,南宁网页设计培训学校,浮梁网站推广文章目录this:this调用属性、方法:this调用构造器:super:super调用属性、方法:super调用构造器:this与super的区别总结:this: this理解为:当前对象 或 当前正在创建的对象 可以调用的结构:属性、方法&…
文章目录
- this:
- this调用属性、方法:
- this调用构造器:
- super:
- super调用属性、方法:
- super调用构造器:
- 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;没加thisthis.name = name;
// id = id; 没加thisthis.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;没加thisthis.name = name;}public void setId(int id) {//id = id;没加thisthis.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("------------------------分割线--------------------");shoes 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(形参列表)“必须声明在当前构造器的首行
⑤ 构造器内部,最多只能声明一个"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;}//构造器1public Shoes() {System.out.println("构造器1");}//构造器2public Shoes(int id){this();//调构造器1System.out.println("构造器2");this.id = id;}//构造器3public 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的idShoes s3 = new Shoes("adidas",2021);System.out.println(s3.getId());}
}
运行结果:
super:
super 关键字可以理解为:父类的
可以用来调用的结构:
属性、方法、构造器
super调用属性、方法:
我们可以在子类的方法或构造器中。通过使用"super.属性"或"super.方法"的方式,显式的调用父类中声明的属性或方法。但是,通常情况下,我们习惯省略"super."
①特殊情况:当子类和父类中定义了同名的属性时,我们要想在子类中调用父类中声明的属性,则必须显式的使用"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;//学号//构造器1public Student(String name, int id) {this.name = name;this.id = id;}//构造器2public 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方法:
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都可以通过栈空间的引用指向堆空间来调用具体的属性.
继续加油~~冲冲冲! ! !