博客
关于我
Java重写override
阅读量:356 次
发布时间:2019-03-04

本文共 1061 字,大约阅读时间需要 3 分钟。

目录


这里有个覆盖的概念,覆盖和重写是一个意思,但是英文在翻译Override时翻译为覆写,覆盖,重载,这就坑爹了,但是我们讲究的是一个共识,重载是同类的同名方法的不同参数,重写是子类重写父类方法要求参数一致。

1 重写(Override)

  从字面上看,重写就是 重新写一遍的意思。其实就是在子类中把父类本身有的方法重新写一遍。子类继承了父类原有的方法,但有时子类并不想原封不动的继承父类中的某个方法,所以在方法名,参数列表,返回类型(除过子类中方法的返回值是父类中方法返回值的子类时)都相同的情况下, 对方法体进行修改或重写,这就是重写。但要注意子类函数的访问修饰权限不能少于父类的。 

方法的重写需要符合下面的三个要点:

      1.“==”: 方法名、形参列表相同。

      2.“≤”:返回值类型和声明异常类型,子类小于等于父类。

      3.“≥”: 访问权限,子类大于等于父类。

1.1 方法重写实例:

/** * 测试重写(override)/覆盖 * @author 赵广陆 * */public class TestOverride {		public static void main(String[] args) {			Horse   h   =  new Horse();			h.run();		}}class  Vehicle {	public  void  run(){		System.out.println("跑....");	}		public   void stop(){		System.out.println("停止!");	}		public  Person   whoIsPsg(){		return  new Person();	}	}class    Horse   extends  Vehicle {	public  void  run(){		System.out.println("四蹄翻飞,嘚嘚的。。。");	}		public  Student   whoIsPsg(){//返回值类型小于等于父类的类型		return  new Student();	}	}

运行效果:

2 总结: 

  1. 发生在父类与子类之间 

  2. 方法名,参数列表,返回类型(除过子类中方法的返回类型是父类中返回类型的子类)必须相同 

  3. 访问修饰符的限制一定要大于被重写方法的访问修饰符(public>protected>default>private) 

  4. 重写方法一定不能抛出新的检查异常或者比被重写方法申明更加宽泛的检查型异常

转载地址:http://xkzr.baihongyu.com/

你可能感兴趣的文章
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>