implements与extends知识点整理
2016-02-24 22:28
225 查看
父类与子类继承关系上的不同:
A a = new B(); 结果a是一个A类的实例,只能访问A中的方法,那么又和A a = new A();有什么区别呢?
***********************************************************************************************
class B extends A
继承过后通常会定义一些父类没有的成员或者方法。
A a = new B();
这样是可以的,上传。
a是一个父类对象的实例,因而不能访问子类定义的新成员或方法。
***********************************************************************************************
假如这样定义:
class A
{
int i;
void f(){}
}
class B extends A
{
int j;
void f(){} //重写
void g(){}
}
然后:
B b = new B();
b就是子类对象的实例,不仅能够访问自己的属性和方法,也能够访问父类的属性和方法。诸如b.i,b.j,b.f(),b.g()都是合法的。此时b.f()是访问的B中的f()
A a = new B();
a虽然是用的B的构造函数,但经过upcast,成为父类对象的实例,不能访问子类的属性和方法。a.i,a.f()是合法的,而a.j,a.g()非法。此时访问a.f()是访问B中的f()
***********************************************************************************************
A a = new B(); 这条语句,实际上有三个过程:
(1) A a;
将a声明为父类对象,只是一个引用,未分配空间
(2) B temp = new B();
通过B类的构造函数建立了一个B类对象的实例,也就是初始化
(3) a = (A)temp;
将子类对象temp转换未父类对象并赋给a,这就是上传(upcast),是安全的。
经过以上3个过程,a就彻底成为了一个A类的实例。
子类往往比父类有更多的属性和方法,上传只是舍弃,是安全的;而下传(downcast)有时会增加,通常是不安全的。
***********************************************************************************************
a.f()对应的应该是B类的方法f()
调用构造函数建立实例过后,对应方法的入口已经确定了。
如此以来,a虽被上传为A类,但其中重写的方法f()仍然是B的方法f()。也就是说,每个对象知道自己应该调用哪个方法。
A a1 = new B();
A a2 = new C();
a1,a2两个虽然都是A类对象,但各自的f()不同。这正是多态性的体现。
***********************************************************************************************
上述摘自http://blog.csdn.net/chen_chun_guang/article/details/6323201
SCJP认证考试题库考点
Given:
10.interface Foo {}
11.class Alpha implements Foo { }
12.class Beta extends Alpha {}
13.class Delta extends Beta {
14.public static void main( String[] args) {
15.Beta x = new Beta();
16. //insert code here
17. }
18. }
Whichcode, inserted at line 16, will cause a
java.lang.ClassCastException?
A.Alpha a = x;
B. Foof= (Delta)x;
C. Foof= (Alpha)x;
D. Beta b = (Beta)(Alpha)x;
Answer:B
A a = new B(); 结果a是一个A类的实例,只能访问A中的方法,那么又和A a = new A();有什么区别呢?
***********************************************************************************************
class B extends A
继承过后通常会定义一些父类没有的成员或者方法。
A a = new B();
这样是可以的,上传。
a是一个父类对象的实例,因而不能访问子类定义的新成员或方法。
***********************************************************************************************
假如这样定义:
class A
{
int i;
void f(){}
}
class B extends A
{
int j;
void f(){} //重写
void g(){}
}
然后:
B b = new B();
b就是子类对象的实例,不仅能够访问自己的属性和方法,也能够访问父类的属性和方法。诸如b.i,b.j,b.f(),b.g()都是合法的。此时b.f()是访问的B中的f()
A a = new B();
a虽然是用的B的构造函数,但经过upcast,成为父类对象的实例,不能访问子类的属性和方法。a.i,a.f()是合法的,而a.j,a.g()非法。此时访问a.f()是访问B中的f()
***********************************************************************************************
A a = new B(); 这条语句,实际上有三个过程:
(1) A a;
将a声明为父类对象,只是一个引用,未分配空间
(2) B temp = new B();
通过B类的构造函数建立了一个B类对象的实例,也就是初始化
(3) a = (A)temp;
将子类对象temp转换未父类对象并赋给a,这就是上传(upcast),是安全的。
经过以上3个过程,a就彻底成为了一个A类的实例。
子类往往比父类有更多的属性和方法,上传只是舍弃,是安全的;而下传(downcast)有时会增加,通常是不安全的。
***********************************************************************************************
a.f()对应的应该是B类的方法f()
调用构造函数建立实例过后,对应方法的入口已经确定了。
如此以来,a虽被上传为A类,但其中重写的方法f()仍然是B的方法f()。也就是说,每个对象知道自己应该调用哪个方法。
A a1 = new B();
A a2 = new C();
a1,a2两个虽然都是A类对象,但各自的f()不同。这正是多态性的体现。
***********************************************************************************************
上述摘自http://blog.csdn.net/chen_chun_guang/article/details/6323201
SCJP认证考试题库考点
Given:
10.interface Foo {}
11.class Alpha implements Foo { }
12.class Beta extends Alpha {}
13.class Delta extends Beta {
14.public static void main( String[] args) {
15.Beta x = new Beta();
16. //insert code here
17. }
18. }
Whichcode, inserted at line 16, will cause a
java.lang.ClassCastException?
A.Alpha a = x;
B. Foof= (Delta)x;
C. Foof= (Alpha)x;
D. Beta b = (Beta)(Alpha)x;
Answer:B
相关文章推荐
- JBPM-工作流
- IEnumerable与IEnumerator区别
- Maven和Gradle
- Canopy使用教程 (3)
- 关于sql中的distinct和top合用
- Linux内核分析 实验一 ——by王玥
- GDKOI总结
- Leetcode 328:Odd Even Linked List
- Rxjava基础
- hdu5631 Rikka with Graph 枚举+并查集
- HBase原理和设计
- Android消息提示方法介绍
- ios 微信支付
- 共用数据的保护
- 第一个python的小程序
- fopen与fopen_s区别与联系
- “Linux内核分析”实验报告一
- JAVASCRIPT入门 之 面向对象+匿名函数
- android versionname一直1.0
- 随堂笔记160224基础语法