为什么抽象方法不能被static修饰?
原因:被static修饰的方法属于类,它还是类的东西,而不是用来给子类继承的。
举例:
如果我们把类比作房子,那么被static修饰的方法就是房子中的一面墙,而抽象方法则可以为房子中的一张白纸,一个桌子等等,墙是没有办法通过继承而迁移的,但桌子,白纸等等,可通过继承将其进行覆盖等操作。
抽象类为什么不能实例化?
在想这个问题的答案之前,我们先想想,实例化的原因:从面向对象的角度想这个问题,我们想实现某个功能,而功能中的方法需要通过对象去调用,而对象是什么呢? 对象就是类的实例,所有的对象都是类的实例。
那么我们再回到问题的本身,抽象,顾名思义就是不具体,类是对对象具体的描述,类相当于图纸,对象相当于产品,而抽象不具体,原因是它没有方法体,不足以形成一个具体的对象,就比如,苹果可以通过实例化产生,而水果不能。
其次我们还考虑到内存问题:对象进行实例化的时候,关键字new向Java申请内存,这个类的成员(成员变量,成员方法)会被保存到内存中,而抽象类,没有具体的成员,没有办法准确的分配内存。
为什么要使用set和get方法呢?
原因是:和Java的封装有关系,在某些类中需要用到private来修饰,这样的话其他的类不能访问这个类里边的变量,就提高了安全性。
但是我们有时需要用到其中变量,那么如何获取呢?这时候就要用到我们说的set()和get()方法。
举例:
尝试直接访问私有属性:
package Test; public class Father { private String name = "apple"; private int numbers=12; }
package Test; public class Son { public static void main(String[]args){ Father father=new Father(); System.out.println(father.name); } }
报错:
在Father类中添加set和get方法:
public String getName() { return name; } public void setName(String name) { this.name = name; }
在Son中通过get方法获取属性的值:
System.out.println(father.getName());
输出:
apple