在Java中,使用{}括起来的代码被称为代码块。
代码块分类:根据其位置和声明的不同,可以分为局部代码块,构造代码块,静态代码块,同步代码块
常见代码块:
a:局部代码块
在方法中出现;限定变量生命周期,及早释放,提高内存利用率
b:构造代码块
在类中方法外出现;多个构造方法方法中相同的代码存放到一起,每次调用构造都执行,并且在构造方法前执行
c:静态代码块
在类中方法外出现,加了static修饰
在类中方法外出现,并加上static修饰;用于给类进行初始化,在加载的时候就执行,并且只执行一次。
概述:多个类中存在相同属性和行为时,将这些内容抽取到单独一个类中,那么多个类无需再定义这些属性和行为,只要继承那个类即可。
格式: class 子类名 extends 父类名 {}
举例:
class S1 {
public static void main(String[] args) {
new S2();
}
public S1(){
System.out.println(“S1”);
}
}
class S2 extends S1 {
public S2 () {
System.out.println(“S2”);
}
}
结果:
S1
S2
分析:
在s2中调用了s1的构造方法。
s2继承了s1。
继承的好处:
a:提高了代码的复用性
b:提高了代码的维护性
c:让类与类之间产生了关系,是多态的前提
注意:java只支持单继承,不支持多继承,也就是一个子类只能继承一个父类。子类只能继承父类所有非私有的成员(父类被private修饰的部分不能被继承)。子类不能继承父类的构造方法,但是可以通过super关键字去访问父类构造方法。
继承中成员变量的关系:
A:子类中的成员变量和父类中的成员变量名称不一样
B:子类中的成员变量和父类中的成员变量名称一样
在子类中访问一个变量的查找顺序(“就近原则”)
a: 在子类的方法的局部范围找,有就使用
b: 在子类的成员范围找,有就使用
c: 在父类的成员范围找,有就使用
d:如果还找不到,就报错
区别:
this 代表的是本类对象的引用
super 代表的是父类存储空间的标识(可以理解成父类的引用,可以操作父类的成员) 子类 可以通过super关键字去访问父类构造方法。
使用:
a:调用成员变量
this.成员变量 调用本类的成员变量
super.成员变量 调用父类的成员变量
b:调用构造方法
this(…) 调用本类的构造方法
super(…) 调用父类的构造方法
c:调用成员方法
this.成员方法 调用本类的成员方法
super.成员方法 调用父类的成员方法
举例:
public class MyTest {
public static void main(String[] args) {
Son son = new Son();
}
}
class Father{
int num=100;
public Father() {
super();//调用父类的空参构造
System.out.println("父类的空参构造");
}
}
class Son extends Father{
public Son() {
super();//调用父类的空参构造
System.out.println("子类的空参构造");
}
}
当我们在创建子类对象时,会先初始化父类,因为我们子类要去继承父类的一些数据,甚至还要去使用它,那如果父类没有先于子类完成对象父类数据的初始化,子类怎么去继承使用,所以说,我们在创建子类对象时,先要完成父类数据的初始化,所以说先要调用父类的构造,完成父类数据的初始化
起始在每个类的构造方法中的第一行,有一条默认语句在调用父类的空参构造 super();
定义:子类中出现了和父类中一模一样的方法声明(方法名,参数列表,返回值类型),也被称为方法覆盖,方法复写。
应用:当子类需要父类的功能,而功能主体子类有自己特有内容时,可以重写父类中的方法。这样,即沿袭了父类的功能,又定义了子类特有的内容。
举例:
public class Fu {
public void show(){
System.out.println("fu Show");
}
}
public class Zi extends Fu {
@Override //注解 可以检测这个方法是不是重写父类的方法
public void show() {
System.out.println("zi Show");
}
public void test(){
System.out.println("子类特有的方法");
}
}
public class MyTest {
public static void main(String[] args) {
//方法重写:当子类出现了和父类一模一样的方法(方法名相同,返回值类型相同,参数列表相同)那么就会发生子类方法覆盖父类方法的现象,我们称这种现像叫方法重写
//为什么要有方法重写
//就是子类对父类的方法实现不满意,或者说想要对父类方法进行扩展,就可以使用方法重写
Zi zi = new Zi();
zi.show();
}
}
final关键字是最终的意思,可以修饰类,变量,成员方法。
由于继承中有一个方法重写的现象,而有时候我们不想让子类去重写父类的方法.这对这种情况java就给我们提供了一个关键字: final
final的特点
修饰类: 被修饰类不能被继承
修饰方法: 被修饰的方法不能被重写
修饰变量: 被修饰的变量不能被重新赋值,因为这个量其实是一个常量
举例:
public class MyTest {
public static final int A=100; //公共的静态常量
public static void main(String[] args) {
//final 最终的,可以修饰变量,成员方法,类
//final 修饰变量,这个变量称为常量
//final 修饰方法,子类不能重写,只能继承
//final 修饰类 此类不能被继承
final int NUM=100; //自定义常量 ,常量的命名规范 字母全部大写
System.out.println(NUM);
int a = MyTest.A;
new Zi().show();
}
}
class Fu{
public final void show(){
System.out.println("父类的final方法");
}
public void show1() { }
public final void show3() {
}
}
class Zi extends Fu{
//@Override
//public void show() {}
}
final class B{
}