Super

在类内使用,代表父类;

super.age;
super.eat();
都是父类的属性或方法。
类似于c++的“类名::方法/属性”

在构造方法中也有作用。
super();
重点
(一)在显式调用父类构造方法时必须 写在第一行。
不写的话,编译器隐式调用。
(二)如果父类自定义了一个有参的构造方法,此时编译器不会自动给出无参的构造方法,若在子类的构造方法中如果不显式调用父类有参的构造方法,那么报错。因为编译器只会自动调用无参数的构造方法,此时父类中没有。

Static

Java 中被 static 修饰的成员称为静态成员或类成员。它属于整个类所有,而不是某个对象所有,即被类的所有对象所共享。静态成员可以使用类名直接访问,也可以使用对象名进行访问。当然,鉴于他作用的特殊性更推荐用类名访问
示例
与静态变量一样,我们也可以使用 static 修饰方法,称为静态方法或类方法。其实之前我们一直写的 main 方法就是静态方法。静态方法的使用如:
示例


需要注意:
1、 静态方法中可以直接调用同类中的静态成员,但不能直接调用非静态成员。如:
示例
如果希望在静态方法中调用非静态变量,可以通过创建类的对象,然后通过对象来访问非静态变量。如:
示例

2、 在普通成员方法中,则可以直接访问同类的非静态变量和静态变量,如下所示:
示例

3、 静态方法中不能直接调用非静态方法,需要通过对象来访问非静态方法。如:
示例


Java 中可以通过初始化块进行数据赋值。如:
示例
在类的声明中,可以包含多个初始化块,当创建类的实例时,就会依次执行这些代码块。如果使用 static 修饰初始化块,就称为静态初始化块。
需要特别注意:静态初始化块只在类加载时执行,且只会执行一次,同时静态初始化块只能给静态变量赋值,不能初始化普通的成员变量。
我们来看一段代码:
示例
运行结果:注意顺序
示例
通过输出结果,我们可以看到,程序运行时静态初始化块最先被执行,然后执行普通初始化块,最后才执行构造方法。由于静态初始化块只在类加载时执行一次,所以当再次创建对象 hello2 时并未执行静态初始化块。

Object

如果一个类没有明确说明继承于哪个类,就是继承与Object类。
一、toString();
其中有一个“toString()”方法,是返回该类的对象的地址,用哈希算法得出的。
在“source-generate toString”中可以重写该方法。
二、equals();
用来判断两个引用是否指向同一个地址。

1
2
3
4
5
6
7
8
9
10
11
12
13
public static void main(String[] args) {
// TODO Auto-generated method stub
Dog one =new Dog();
Dog two =new Dog();
one.eat();
one.age=10;
two.age=10;
if(one.equals(two)){
System.out.println("他门是一样的!");
}else{
System.out.println("他们是不一样!");
}
}

results:
他们是不一样!


“source-generate hash() and equal()”中重写

1
2
3
4
5
6
7
8
9
10
11
12
13
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Animal other = (Animal) obj;
if (age != other.age)
return false;
return true;
}

变成判断他们的属性值是否相等了。
results:
他们是一样的!

Final

修饰类:该类不可被继承
修饰方法:该方法不可被重写
修饰属性:该类不会被隐式初始化,或在构造方法中赋值
修饰变量:只能赋值一次。(常量)