20172325 2017-2018-2 《Java程序设计》第八周学习总结
教材学习内容总结
1.关于绑定
- 绑定:在执行程序时产生一个请求事件,需要执行一段代码来来完成方法调用,即一个方法调用与一个方法定义的绑定。
- 后绑定:后绑定就是延迟绑定的情况。(后绑定的效率低于编译阶段的绑定效率)
2.由继承实现多态性
- 一个引用变量可以指向由继承关系的任何类的任何对象;
- 实际将调用的方法版本取决于对象的类型而不是引用变量的类型;
3.利用接口实现多态性
- 接口引用变量可以指向实现该接口的任何类的任何对象。
- 使用接口引用变量时,只能调用定义在接口中的方法,其他的不可调用,如果已知这样的方法调用是有意义的,则需要进行对象类型转换
- 接口名也可以用作方法参数的类型,使得任何实现同一个接口的类对象都可以作为参数传给的方法。
4.排序
- 排序有两种方法,分别为选择性排序和插入性排序
- 选择性排序:扫描整个数列找到最小值并与数列中第一个位置的值交换,如此循环,直到数列有序排列。
- 插入法排序:从左往右第一次排序从第二个数开始,与之前的数比较,在之前的数中合适的位置插入不断重复。
- 比较:两者的效率相同,但是选择法排序的实际交换次数比插入法排序少,所以在两者之间选择的话,选择法排序会更好一些。
5.搜索
- 线性搜索:从一个端点开始,以线性方式扫描整个搜索池,就是按照先后顺序依次进行搜索,传统意义上的依次搜索。
- 二分搜索:对一组已经进行过排序的数据进行二分搜索,从中间分开,依次寻找更接近目标的区间,最后达到搜索目标。
- 比较:
(1)二分搜索的前提是数据已经经过了排序,如果没有进行排序,则考虑选择线性搜索。
(2)在满足二分搜索的前提下,如果数据量较大,则二分搜索需要的时间可能会较少,即效率更高。
(3)在数据已经排序(升或降)的基础下,二分效率更高;在以数组形式出现时,线性效率更高。
教材学习中的问题和解决过程
- 问题1:实际调用的方法版本取决于对象的类型而不是引用变量的类型。此话什么意思?
- 问题1解决方案:询问了学长,并且具体的做了如下的一个实验,能够较为清楚的解释这句话。
···
public class Polymorphism {
public static void main(String[] args) {
//既然是多态,java 中重载和重写都是多态的体现,你问的这句话肯定不属于重载则用重写来解释
// 这里声明了一把枪,变量为gun,但他却指向了一把Ak47对象,也就是说 gun虽然是Gun的引用,但实际是一个Ak47对象
//那么gun.shot其实调用的是Ak47.shot 而不是Gun自己的shot
Gun gun = new Ak47();
gun.shot();
}
}
class Gun {
public void shot() {
System.out.println("突!");
}
}
class Ak47 extends Gun {
public void shot() {
System.out.println("突!突!突!突!突!");
}
···}
- 问题2:对接口实现多态性那一部分理解的不是很好
- 问题2解决方案:寻找资料的时候发现了这样一个问答,虽然说没有具体指导问题中的代码,但是根据他们的问答确实很好的帮助了我理解接口实现多态性。
代码调试中的问题和解决过程
- 问题1:XXXXXX
- 问题1解决方案:XXXXXX
- 问题2:XXXXXX
- 问题2解决方案:XXXXXX
- ...
代码托管
脚本截图
上周考试错题总结
-
- Inheritance through an extended (derived) class supports which of the following concepts?
A . interfaces
B . modulary
C . information hiding
D . code reuse
E . correctness
解析 通过扩展一个类并继承它,新类不必重新实现任何这些继承的方法或实例数据,从而节省了程序员的工作量。 因此,代码重用是为了您的需要扩展它而重用其他代码的好处。
- Inheritance through an extended (derived) class supports which of the following concepts?
- 2 . A variable declared to be of one class can later reference an extended class of that class. This variable is known as
A . protected
B . derivable
C . cloneable
D . polymorphic
E . none of the above, a variable declared to be of one class can never reference any other type of class, even an extended class
解析:多态意味着变量可以有多种形式。 在普通情况下,Java被强烈定义,即一旦声明为某个类型的变量永远不会变为不同的类型。 这是一个例外,多态变量可以是任何类型的派生类(尽管不是同时,变量可以从一种类型变为另一种类型)。
原因:未能正确理解题意,以为是要在变量前什么类型。
-
- Which of the following is an example of multiple inheritance?
A . A computer can be a mainframe or a PC
B . A PC can be a desktop or a laptop
C . A laptop is both a PC and a portable device
D . A portable device is a lightweight device
E . Macintosh and IBM PC are both types of PCs
解析:多重继承意味着一个给定的类继承了多个父类。在上面列出的那些中,笔记本电脑继承了来自PC和便携式设备的特性。A,B和E中的答案都是单个继承的例子,其中一个班级至少有两个孩子(在A中,计算机有儿童大型机和PC,B,PC有儿童台式机和笔记本电脑,E,PC有孩子Macintosh和IBM PC)。答案D表示一个类的属性。
- Which of the following is an example of multiple inheritance?
-
- In order to determine the type that a polymorphic variable refers to, the decision is made
A . by the programmer at the time the program is written
B . by the compiler at compile time
C . by the operating system when the program is loaded into memory
D . by the Java run-time environment at run time
E . by the user at run time
解析:这道题目是在问是在什么阶段确定多态变量所引用的类型,这也是属于第十章内容。对于多数情况下的这种请求,这种绑定是发生在编译阶段,但是对于多态性引用,这种绑定要延迟到程序运行才能执行,并且要绑定的方法取决于当时引用变量所引用的对象,这种被延迟的请求事件被称为后绑定或动态绑定。
结对及互评
- In order to determine the type that a polymorphic variable refers to, the decision is made
点评模板:
- 博客中值得学习的或问题:
- xxx
- xxx
- ...
- 代码中值得学习的或问题:
- xxx
- xxx
- ...
- 基于评分标准,我给本博客打分:XX分。得分情况如下:xxx
- 参考示例
点评过的同学博客和代码
- 本周结对学习情况
- 结对同学学号1
- 结对照片
- 结对学习内容
- XXXX
- XXXX
- ...
- 上周博客互评情况(只要链接,具体点评放相应博客下)
- 学号1
## 学习进度条
代码行数(新增/累积) | 博客量(新增/累积) | 学习时间(新增/累积) | 重要成长 | |
---|---|---|---|---|
目标 | 5000行 | 30篇 | 400小时 | |
第一周 | 200/200 | 2/2 | 20/20 | |
第二周 | 300/500 | 2/4 | 18/38 | |
第三周 | 500/1000 | 3/7 | 22/60 | |
第四周 | 300/1300 | 2/9 | 30/90 |
参考资料
原文地址:https://www.cnblogs.com/20172325DYK/p/8982580.html