为什么要protected类的构造器?很多人都想不明白,下面简要说明一下这个访问控制符的真正含义和用处,类封装的意义:
我们在使用某个java文档中的类的时候,经常会看到protected修饰构造器的类,我们会想,为什么不直接public,反正只是多做了一步继承,并没有太大的差别,该访问的都能访问。
于是我们会想直接使用这些包里的这些protected修饰构造器的类是不是会产生什么危害?其实也想不出来有什么会危害到运行的地方。
我们在使用第三方库的时候,不可能进入它的包里面来new这个类,所以也就使它只能被继承,我们不可能进入到它的包中使用它。
然后我们想像一下:比如我们自己准备创建一个包给别人使用,写了很多类,包括我想让用户使用的类,也包括为了方便复用代码,抽象出来一个父类,这个父类并不是我想提供给用户的,所以我需要用protected修饰构造器来规定,用户想要使用这个父类也必须继承来赋予它一定的意义,就像这个父类的其他子类一样。
举一个常见的例子:
比如我有一群鸟给其他用户使用,为了做这一群,八哥,鹦鹉,蓝雀,我抽象出来一个鸟类。其他用户想要使用这个鸟类也必须继承,不然没有鸟类的实例这种说法,逻辑上过不去。
这实际上就是我们自己写包的一种规范,自己的包中的基类必须用protected修饰,否则的话,就有如下危害:
1、用户无法访问子类的风险(default或者private修饰基类构造器)
2、错误的让用户能创建一个不符合逻辑的实例的风险(public修饰基类构造器)
3、用户无法使用基类自己创建新的子类。(同1)
所以我们自己写包的话,必须用public修饰想要公开的类,用protected修饰基类的构造器,真正的想要让用户使用的类,用public修饰构造器
类的话只有default和public修饰符,所以不应该出现,public类,却用default和private修饰全部的构造器的类。只要别全部都是private和default就行。
这样做没意义:继承都继承不了。看的见,没法用,除非是类方法。