多个类中存在相同属性和行为时,将这些内容抽取到单独一个类 中, 那么多个类无需再定义这些属性和行为,只要继承那个类便可java
多个类称为子类(派生类),单独的这个类称为父类(基类或超类)编程
做用:app
类继承语法规则:ide
class 子类名 extends 父类名{ }
在子类中能够根据须要对从父类中继承来的方法进行改造,也称为方法的重置、覆盖。在程序执行时,子类的方法将覆盖父类的方法测试
要求:this
子类重写的方法必须和父类被重写的方法具备相同的方法名称、参数列表code
子类重写的方法的返回值类型不能大于父类被重写的方法的返回值类型orm
子类重写的方法使用的访问权限不能小于父类被重写的方法的访问权限对象
子类方法抛出的异常不能大于父类被重写方法的异常blog
子类与父类中同名同参数的方法必须同时声明为非static的(即为重写),或者同时声明为 static的(不是重写)。由于static方法是属于类的,子类没法覆盖父类的方法
当子父类出现同名成员时,能够用super代表调用的是父类中的成员
super的追溯不只限于直接父类
this表明本类对象的引用,super表明父类的内存空间的标识
当父类中没有空参数的构造器时,子类的构造器必须经过this(参数列表)或者super(参数列表)语句指定调用本类或者父类中相应的构造器。同时,只能”二选一” ,且必须放在构造器的首行
对象的多态性:父类的引用指向子类的对象
Java引用变量有两个类型:编译时类型和运行时类型
编译时,看左边;运行时,看右边
子类中定义了与父类同名同参数的方法,在多态状况下,将此时父类的方法称为虚拟方法,父类根据赋给它的不一样子类对象,动态调用属于子类的该方法。这样的方法调用在编译期是没法肯定的
Person e = new Student(); e.getInfo(); //调用Student类的getInfo()方法
x instanceof A:检验x是否为类A的对象,返回值为boolean型
int a=(int)1200L;
对Java对象的强制类型转换称为造型
Object类是全部Java类的根父类
若是在类的声明中未使用extends关键字指明其父类,则默认父类为java.lang.Object类
method(Object obj){…} //能够接收任何类做为其参数
==:
用“==”进行比较时,符号两边的数据类型必须兼容(可自动转换的基本数据类型除外),不然编译出错
equals():能够重写
obj1.equals(obj2)
缘由:在这些类中重写了Object类的equals()方法
任何状况下,x.equals(null),永远返回是“false”
针对八种基本数据类型定义相应的引用类型—包装类(封装类)
JDK1.5以后,支持自动装箱,自动拆箱。但类型必须匹配
基本数据类型包装成包装类的实例 ---装箱
int i = 500; Integer t = new Integer(i); Long l = new Long(“asdf”); //NumberFormatException
得到包装类对象中包装的基本类型变量 ---拆箱
//调用包装类的.xxxValue()方法: boolean b = bObj.booleanValue();
字符串转换成基本数据类型
//经过包装类的构造器实现: int i = new Integer(“12”); // 经过包装类的parseXxx(String s)静态方法: Float f = Float.parseFloat(“12.1”);
基本数据类型转换成字符串
//调用字符串重载的valueOf()方法: String fstr = String.valueOf(2.34f); // 更直接的方式: String intStr = 5 + “”;