1)基本类型转换
a)自动类型转换--》小类型赋值大类型
b)手动(强制)类型转换--》大类型赋值给小类型
2)引用类型转换
a)自动类型转换--》子类型赋值给超类型
b)手动(强制)类型转换--》超类型赋值给子类型
* 子类型:继承链下面的类型
* 超类型:继承链上面的类型
* 例如:
* 继承链:中国人-》人-》动物-》生物-》Object
* 子类型:假设-》人
* 对应人的超类型:动物-》生物-》Object
* A类型 引用变量=B类型的值;
* 引用类型转换的原则
* a)编译看引用类型:编译时候,如果a类型是b引用类型的超类型--》可以自动类型转换--》否则编译错误
* b)运行看对象类型:运行时候,如果a类型是b引用指向对象类型超类型--》可以类型转换--》否则运行错误
* 强转语法
* A类型 引用变量=(A类型)B类型的值;
* 怎么检查-我们的强制类型转换-》是否可以成功进行
* instanceof运算符
* 语法:
* 引用 instanceof 目标类型
* 结果值类型:布尔值
* true:引用指向的对象的类型可以转换为目标类型
* false:引用指向的对象的类型不可以转换为目标类型
1、super关键字作用?
方便在子类中调用【当前对象】的【继承链】上的资源(属性和方法)
2.this和super的对比
1)都是指向当前对象
2)调用资源(成员变量,成员变量)不一样
this:【当前类】【当前类的父类】【继承链上其他类】
super:【当前类的父类】【继承链上其他类】
3)位置:成员方法,构造器---》静态的结构不能直接使用
3.super的作用:
1)当成员方法重写的时候
super.成员方法-》调用超类型被重写的方法
2)当前成员变量同名的时候(不会遇到)
super.成员变量-》调用超类型同名的变量
3)调用父类指定的构造器-进行数据初始化
创建对象的时候-->做的事情
1)在堆里创建出一个对象
2)通过对象调用构造器进行数据初始化
3)返回对象地址
--》在有继承的时候--》创建对象的时候--》调用构造器
1)从继承链上到下调用每个类的构造器
--》调用父类构造器的原因--》进行对应的父类的数据初始化
--》默认空构造器-》没有数据初始化
2)调用父类指定的构造器-进行数据初始化
语法:super(直接父类构造器参数列表);--》在子类构造器调用父类指定的匹配参数的构造器
1)必须在构造器中
2)必须在第一句
3)构造器里如果没有显示的super(参数列表)代码,那么默认加上super();编写了不会加入super();