1.java继承时,子类Override父类方法的限制:从这里抄的
https://www.cnblogs.com/aademeng/articles/11230526.html
遵循的规则:
【1】访问修饰符的限制一定要不小于被重写方法的访问修饰符
比如:Object类有个toString()方法,开始重写这个方法的时候我们总容易忘记Public修饰符,出错的原因就是:没有加任何访问修饰符的方法具有包访问权限,Default访问权限小于Public访问权限,所以编译器出错。
【2】参数列表必须与被重写方法的相同。
【3】重写的方法的返回值必须和被重写的方法的返回一致或者兼容;
【4】重写的方法所抛出的异常必须和被重写方法的所抛出的异常一致,或者是其子类;
【5】被重写的方法不能为private,子类再写一个同名的方法并不是对父类方法进行重写(Override),而是重新生成一个新的方法;
【6】静态方法不能被重写。
【注】:方法是静态的、他的行为就不具有多态性。静态方法是与类、而非单个对象相关联的。重写依赖于类的实例,而静态方法和类实例并没有什么关系;而且静态方法在编译时就已经确定,而方法重写是在运行时确定的(动态绑定)。
1)父类的静态方法不能被子类覆盖为非静态方法。(会编译出错)
2)父类的非静态方法不能被子类覆盖为静态方法。 3)构造方法不能被重写;因为构造方法时隐式的static方法。其实这个问题回答切入点很多,首先构造方法无返回值、方法名必须和所在类名相同,这一点就必杀了子类无法重写父类构造方法。另外多态方面、重写是多态的一种体现方式、假设在子类重写了构造方法是成立的、那么子类何谈实例成父类。另外重要得一点、子类可以使用super();调用父类的构造方法、且必须放在子类构造方法内的第一行。
【7】不能重写被标识为final的方法,子类中必须重写父类中的abstract方法 。
因此,abstract方法不能被static修饰,
还是之前的登录的例子,因为最开始的类没有考虑继承,将Builder getBuilder设成了private, 原本只需要token,不需要cookie。因为不想改原来的实现,于是写了个子类,发现调用父类的getBuilder,只好将父类的getBuilder定义成public
编译通过运行成功
// 父类中:// 之前是private,后来改成public,可以在子类中@Override父类中的方法getBuilder public Invocation.Builder getBuilder(String path) { ClientConfig configuration = new ClientConfig(); configuration = configuration.property(ClientProperties.CONNECT_TIMEOUT, 30000); configuration = configuration.property(ClientProperties.READ_TIMEOUT, 30000); Client client = ClientBuilder.newBuilder().withConfig(configuration).hostnameVerifier((s1, s2) -> true).register(new JacksonFeature()).build(); if (baseUrl == null) { baseUrl = EnvConfig.base_url; } return client.target(baseUrl).path(path).register(MultiPartFeature.class) .request(MediaType.APPLICATION_JSON) .header("token", token); } // 子类中 @Override public Invocation.Builder getBuilder(String path) { ClientConfig configuration = new ClientConfig(); configuration = configuration.property(ClientProperties.CONNECT_TIMEOUT, 30000); configuration = configuration.property(ClientProperties.READ_TIMEOUT, 30000); Client client = ClientBuilder.newBuilder().sslContext(ServiceTestLogin.createIgnoreVerifySSL()).withConfig(configuration).hostnameVerifier((s1, s2) -> true).register(new JacksonFeature()).build(); Invocation.Builder builder = client.target(baseUrl).path(path).register(MultiPartFeature.class) .request(MediaType.APPLICATION_JSON); if (StringUtils.isNotBlank(token)) { builder = builder.header("token", token); } if (StringUtils.isNotBlank(cookieValue)) { builder = builder.header("Cookie", cookieValue); } return builder; }
2.父类和子类分属不同的project,需要将父类所在的project编译,然后将jar包导入子类所在的project。之前不知道如何更新,经过领导的知道才知道。
2a.编译打包父类所在的project,执行:mvn install -DskipTests=true
2b.intellij idead中找到引用父类包的pom.xml文件,点击 Maven -> Reload Project
2c.在子类所在project中打开父类的实现,发现已经是新代码了。