说在前面:不能
静态的方法和变量都是属于类的,在该类的字节码文件被加载到内存就分配了相应的内存空间。所以说,即便子类中有一个和父类的类方法长得一摸一样的类方法(方法体可能不同),也不能算重写,因为两者占据不同的内存空间,这个子类的静态方法是子类自己的,与父类没有关系。
看看代码及结果就明白了(下有解释)
class Test_dad{
public static void today() {
System.out.println("这是父类静态方法的输出");
}
}
class Test_son extends Test_dad{
public static void today() {
System.out.println("这是子类静态方法的输出");
}
}
public class E{
public static void main(String args[]) {
Test_dad.today(); //静态方法可以通过类名调用,观察结果
System.out.println("*********************");
Test_dad dad=new Test_dad(); //静态方法也可以通过对象名调用,观察结果
Test_son.today(); //重头戏来了,看看用子类类名调用静态方法today()输出什么结果
System.out.println("*********************");
Test_son son=new Test_son();
son.today(); //子类对象调用静态方法today()
System.out.println("*********************");
//a为上转型对象,看看它调用什么方法
Test_dad a=new Test_son();
a.today();
}
}
这是输出结果
这是父类静态方法的输出
*********************
这是子类静态方法的输出
*********************
这是子类静态方法的输出
*********************
这是父类静态方法的输出
当通过子类或子类的实例来调用这个子类父类同名的静态方法时,毫无疑问,调用的是子类“看似”重写父类的静态方法(实则是子类新增的方法);
当通过上转型对象调用这个同名静态方法时,就体现了“继承”这一特点,即上转型对象只能操作子类继承或隐藏的成员方法,不可操作子类新增的成员变量和成员方法,由此可见,子类继承了父类的静态方法(today()),而子类中的同名静态方法只能算是子类新增的成员方法。
上转型对象调用子类继承或子类重写的方法时,其作用等价于子类对象去调用这些方法!这里上转型对象调用的方法是子类新增的,它调用不了,只能调用父类的啦!
总结
子类可以继承父类的静态方法,但不能重写它。
当子类或子类对象调用该静态方法时,调用的子类的静态方法;
当子类的上转型对象调用该静态方法时,调用的是子类继承的静态方法(即父类的)。