20172301 2017-2018-2 《程序设计与数据结构》第十周学习总结
教材学习内容总结
- 集合:是一个对象。
- 同构和异构:取决于集合保存的是否是类型全部都相同的对象。
ArrayList由于其多态性,所以可以存储任何类型的对象,是异构 - 线性数据结构:
- 队列:
先进先出 - 堆栈:
后进先出
- 队列:
- 非线性数据结构:
- 树:由一个根节点和构成层次结构的多个节点组成。
- 内部节点:除根节点外的所有节点
- 叶节点:没有子节点的节点(就是在周围两边的节点)
- 树的结构从上到下,根节点在顶层,叶节点在底层
- 二叉树:每个节点有不超过两个的子节点。(有两个枝丫)
- 图:使用常见的边来连接节点。
- 树:由一个根节点和构成层次结构的多个节点组成。
教材学习中的问题和解决过程
-
问题1:persistence (持续化)和 serialization(序列化)区别。这是针对这周错题里的,单独分析一下。
-
问题1解决方案:
- 首先,在查阅了一些资料之后,我对这个问题有一定的理解,但是不是很懂。详细请看错题理解。跳转
- 然后,我在蓝墨云上请教了王老师,王老师给我了一个链接。
参考资料:序列化和持久化的区别与联系
序列化和持久化很相似,有些人甚至混为一谈,其实还是有区别的,序列化是为了解决对象的传输问题,传输可以在线程之间、进程之间、内存外存之间、主机之间进行。我之所以在这里提到序列化,是因为我们可以利用序列化来辅助持久化,可以说凡是可以持久化的对象都可以序列化,因为序列化相对容易一些(也不是很容易),所以主流的软件基础设施,比如.net和java,已经把序列化的框架完成了。
所以,序列化只是辅助持久化而已,是有一定区别的,换句话说,实现持久化就可以实现序列化。
-
问题2:list下ArrayList和Linked和Vector的区别
-
问题2的解决方案:在list下这几个有什么区别。ArrayList我们都熟悉,是以数组的形式来实现的。
- Vector、ArrayList都是以类似数组的形式存储在内存中,LinkedList则以链表的形式进行存储。
- List中的元素有序、允许有重复的元素,Set中的元素无序、不允许有重复元素。
- Vector线程同步,ArrayList、LinkedList线程不同步。
- LinkedList适合指定位置插入、删除操作,不适合查找;ArrayList、Vector适合查找,不适合指定位置的插入、删除操作。
- ArrayList在元素填满容器时会自动扩充容器大小的50%,而Vector则是100%,因此ArrayList更节省空间。
参考资料:[Vector,ArrayList, LinkedList的区别](https://www.cnblogs.com/zkk-wust/p/7250776.html) |
-
问题3:Java集合不能存放基本数据类型,只存放对象的引用。那么,为什么ArrayList可以存放int类型的数据?
-
问题3解决方案:
可以通过包装类把基本类型转为对象类型,存放引用就可以解决这个问题。更方便的,由于有了自动拆箱和装箱功能,基本数据类型和其对应对象(包装类)之间的转换变得很方便,想把基本数据类型存入集合中,直接存就可以了,系统会自动将其装箱成封装类,然后加入到集合当中。
也就是说,集合类可以存放基本类型的包装类。那么,因为系统可以自动的装箱和拆箱,我们就可以不用考虑添加的元素是否是基本数据类型了。
参考资料: [Java集合不能存放基本数据类型,只存放对象的引用](https://blog.csdn.net/zm13007310400/article/details/71256507) |
代码调试中的问题和解决过程
-
问题1:在做PP13.3的时候,我想逐个比较列表中的数。结果
-
问题1解决方案:通过两次结果的对比,我发现了,这个循环作用是,前一个和后一个相比较,并不是第一个依次与后几个比较。这是和题意相悖的。然后,我总结我需要运用两个循环,所以我定义了两个指针。让他们分别去循环。
代码托管
上周考试错题总结
-
An exception can produce a "call stack trace" which lists B
A . the active methods in the order that they were invoked
B . the active methods in the opposite order that they were invoked
C . the values of all instance data of the object where the exception was raised
D . the values of all instance data of the object where the exception was raised and all local variables and parameters of the method where the exception was raised
E . the name of the exception thrown -
理解:首先,我们要清楚
call stack trace
是什么意思,在书P344,堆栈踪迹。我们可能不是很熟悉,但是我们应该清楚什么是堆栈。而堆栈是一种以
后进先出方式管理数据的线性数据结构。 堆栈跟踪提供了储存在运行时堆栈中的发生异常方法、文件和代码行号。如果是,先进后出,那么就是反序输出的。 -
The idea that an object can exist separate from the executing program that creates it is called C
A . transience
B . static
C . persistence
D . serialization
E . finality -
理解:其实我觉得这道题是超纲了。先不说我们不清楚选项的意思。这里我唯一看懂的就一个B静态的。
- 那么,我们来看下解析:
对象存储在内存中,当它们不再被引用时,被垃圾回收器回收。当Java程序终止时,没有对象被引用,因此所有对象都被回收。但是,可以保存任何给定的对象以供将来使用。这种特性称为持久性,通过将对象的实例数据保存到文件中来实现这一点。这可以通过将每个实例数据写入数据文件来实现,但是使用对象序列化简化。
- 垃圾回收的什么我们都懂,问题是persistence(持久化)是什么。
持久化(Persistence),即把数据(如内存中的对象)保存到可永久保存的存储设备中(如磁盘)。持久化的主要应用是将内存中的对象存储在数据库中,或者存储在磁盘文件中、XML数据文件中等等。
- 其实,就是把对象存入文件或者数据库中,跟IO流有关系?
同时,我也查了一下其他的选项。E应该是常量化,A不知道,主要是D序列化。我们再看一下序列化的定义:
序列化是将对象状态转换为可保持或传输的格式的过程在MFC中储存或恢复对象的过程即为Serialization,也称为Persistent(永续生存)。在序列化期间,对象将其当前状态写入到临时或永久性存储区(存入文件中)。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。以此达到面向对象中的永续生存。
不看不知道,一看吓一跳。序列化也称为Persistent(永续生存)。难不成他们还有渊源?为什么不选D而选C呢?
-
所以,我查到了java中的Serialiazation机制
Serialization是指把类或者基本的数据类型持久化(persistence)到数据流(Stream)中,包括文件、字节流、网络数据流。
JAVA中主要靠两个类:ObjectOuputStream和ObjectInputStream。 他们是JAVA IO系统里的OutputStream和InputStream的子类。 -
我们接着查下API加以理解接口Serializable。
-
其实,我还是不理解,或者说,使用serialization也必须持久化,所以才选的C,不明白别的同学怎么想的吧,对我来说有点难度。
参考资料:
Persistence VS Serialization
serialization
持久化
什么是java persistence
-
Character streams manage C
A . byte-sized data
B . binary data
C . Unicode characters
D . ASCII characters
E . compressed data -
理解:字符流用于16位Unicode字符。这与用于管理任何字节大小数据的字节流不同,包括ASCII字符和其他类型的二进制数据。
-
System.err is a(n) C
A . input stream
B . GUI dialog box that indicates when an error has arisen
C . object
D . Error subclass
E . RuntimeException subclass -
理解:这题确实是鲁莽了。在书P352:
System类中有三种对象引用变量(in, out, err),分别代表了三种标准I/O流。
所以,System.err应该是一个对象,代表的是错误流。
-
Assume infile is a BufferedReader for a textfile and that the textfile is empty. What is returned from the message infile.readLine( ); ? B
A . 0
B . null
C . a special character known as the End-of-file marker (EOF)
D . none of the above, the message causes a NullPointerException to be thrown
E . none of the above, the message causes a EndOfFileException to be thrown -
理解:这道题,我选了D。那为什么不会抛出异常呢。我们需要了解空指针异常有哪些。
参考资料:[一般报java.lang.NullPointerException的原因有以下几种](https://blog.csdn.net/zwhfyy/article/details/885588/) |
恍然大悟。
- While the Exception class is part of java.lang, IOException is part of java.io. A
A . true
B . false - 理解:如图。
结对及互评
- 博客互评情况
其他
编程方面一切如常,但是测试方面却有了大幅度的下滑。其实,我感觉测试难度并不小。而我每次都是掐着时间,30道题大约40分钟。所以,这次正确率就比较低了。其实,我感觉,并不是我没有努力,只是我的进步没有其他人大吧。我也注意到这次测试有满分的,同样也有30分钟以内做完题目的。所以,我觉得应该仔细查找一下自己的失误在哪里,毕竟大家学的都是一本教材。另一方面,由于四则运算项目的原因,我并没有详细的预习11章,这是应该避免的。调整好自己的状态,要能承担的起生活的压力。不管是学习,还是其他。希望自己能够调整好心态,迎接之后的挑战。
学习进度条
代码行数(新增/累积) | 博客量(新增/累积) | 学习时间(新增/累积) | 重要成长 | |
---|---|---|---|---|
目标 | 5000行 | 30篇 | 400小时 | |
第一周 | 122/122 | 1/1 | 20/20 | |
第二周 | 487/609 | 1/2 | 18/38 | |
第三周 | 482/1091 | 1/3 | 22/60 | |
第四周 | 1357/2448 | 1/4 | 20/80 | |
第五周 | 628/3106 | 1/5 | 20/100 | |
第六周 | 566/3672 | 2/7 | 20/120 | |
第七周 | 934/4606 | 1/8 | 25/145 | |
第八周 | 2407/7013 | 1/9 | 30/175 | |
第九周 | 1504/8517 | 1/10 | 20/195 | |
第十周 | 981/9498 | 1/11 | 18/213 |