Java多态性 父类引用指向子类对象
2015-05-30 19:54
465 查看
首先,我们看看关于重载,和覆盖(重写)的简明定义:
方法重载:如果有两个方法的方法名相同,但参数不一致,哪么可以说一个方法是另一个方法的重载。
方法覆盖:如果在子类中定义一个方法,其名称、返回类型及参数签名正好与父类中某个方法的名称、返回类型及参数签名相匹配,那么可以说,子类的方法覆盖了父类的方法
我们重点说说覆盖问题,以如下代码为例:
[java] view
plaincopyprint?
public class People {
public String getName() {
return "people";
}
}
public class Student extends People {
public String getName() {
return "student";
}
}
public static void main(String[] args) {
People p=new People();
System.out.println(p.getName());//运行结果为people
Student s=new Student();
System.out.println(s.getName());//运行结果为student
People pp=new Student();
System.out.println(pp.getName());//运行结果为student
}
上述结果说明:student类的getName方法成功覆盖了父类的方法
我们再来看看变量的覆盖:
[java] view
plaincopyprint?
public class People {
protected String name="people";
}
public class Student extends People {
protected String name="student";
}
public static void main(String[] args) {
People p=new People();
System.out.println(p.name);//运行结果为people
Student s=new Student();
System.out.println(s.name);//运行结果为student
People pp=new Student();
System.out.println(pp.name);//运行结果为people
}
通过运行结果我发现:变量的覆盖实际上与方法的不尽相同.
用我自己的话说:变量的覆盖最多只能算是半吊子的覆盖.
要不然,向上转换与不会发生数据丢失现象
People pp=new Student();
System.out.println(pp.name);//运行结果为people
就我个人的经验来说:变量的覆盖很容易让人犯错误.让人感觉又回到了C++的继承[这里不是指C++带virtual的继承]
最后我们再来看一段代码:
[java] view
plaincopyprint?
public class People {
protected String name="people";
public String getName() {
return name;
}
}
public class Student extends People {
protected String name="student";
public String getName() {
return name;
}
}
[java] view
plaincopyprint?
main(String[] args) {
People p=new People();
System.out.println(p.getName());//运行结果为people
Student s=new Student();
System.out.println(s.getName());//运行结果为student
People pp=new Student();
System.out.println(pp.getName());//运行结果为student
}
显然,如此的覆盖,才是对我们更有用的覆盖,因为这样才能达到:把具体对象抽象为一般对象的目的,实同多态性
方法重载:如果有两个方法的方法名相同,但参数不一致,哪么可以说一个方法是另一个方法的重载。
方法覆盖:如果在子类中定义一个方法,其名称、返回类型及参数签名正好与父类中某个方法的名称、返回类型及参数签名相匹配,那么可以说,子类的方法覆盖了父类的方法
我们重点说说覆盖问题,以如下代码为例:
[java] view
plaincopyprint?
public class People {
public String getName() {
return "people";
}
}
public class Student extends People {
public String getName() {
return "student";
}
}
public static void main(String[] args) {
People p=new People();
System.out.println(p.getName());//运行结果为people
Student s=new Student();
System.out.println(s.getName());//运行结果为student
People pp=new Student();
System.out.println(pp.getName());//运行结果为student
}
上述结果说明:student类的getName方法成功覆盖了父类的方法
我们再来看看变量的覆盖:
[java] view
plaincopyprint?
public class People {
protected String name="people";
}
public class Student extends People {
protected String name="student";
}
public static void main(String[] args) {
People p=new People();
System.out.println(p.name);//运行结果为people
Student s=new Student();
System.out.println(s.name);//运行结果为student
People pp=new Student();
System.out.println(pp.name);//运行结果为people
}
通过运行结果我发现:变量的覆盖实际上与方法的不尽相同.
用我自己的话说:变量的覆盖最多只能算是半吊子的覆盖.
要不然,向上转换与不会发生数据丢失现象
People pp=new Student();
System.out.println(pp.name);//运行结果为people
就我个人的经验来说:变量的覆盖很容易让人犯错误.让人感觉又回到了C++的继承[这里不是指C++带virtual的继承]
最后我们再来看一段代码:
[java] view
plaincopyprint?
public class People {
protected String name="people";
public String getName() {
return name;
}
}
public class Student extends People {
protected String name="student";
public String getName() {
return name;
}
}
[java] view
plaincopyprint?
main(String[] args) {
People p=new People();
System.out.println(p.getName());//运行结果为people
Student s=new Student();
System.out.println(s.getName());//运行结果为student
People pp=new Student();
System.out.println(pp.getName());//运行结果为student
}
显然,如此的覆盖,才是对我们更有用的覆盖,因为这样才能达到:把具体对象抽象为一般对象的目的,实同多态性
相关文章推荐
- java执行class指定第三方jar路径
- java.lang.OutOfMemoryError: PermGen space错误解决
- Eclipse远程Debug
- Java如何实现点击按钮弹出保存文件的选项
- 数组java.lang.NullPointerException问题
- JAVA 动态代理与AOP编程(面向切面编程)
- spring mvc结合freemarker,使用hibernate validation框架做校验及国际化
- java学习之泛型
- Java_Web之神奇的Ajax
- Java连接数据库(SQL Server)
- Java 线程池
- JAVA和JVM运行原理揭秘
- 二分查找-Java版
- 使用Spring 3的@value简化配置文件的读取 (转)
- Java_Socket简单通信
- spring AOP
- 【java正则】判断日期格式及非负浮点数
- 关于在 eclipse R cannot be resolved to a variable 解決
- 关于spring的注解方式注入默认值(转) -- 首字母小写
- struts2总结二:第一个简单的struts2程序