20155201 2016-2017-2 《Java程序设计》第六周学习总结


教材学习内容总结

  • 第十章 输入/输出

    • 字节输入类:
    1. Java将输入/输出抽象化为串流,数据有来源及目的地,衔接两者的事串流对象。从应用程序角度来看,将数据从来源取出,使用输入串流java.io.InputStream;如果将数据写入目的地,可以使用输出串流java.io.OutputStream

    2. 串流继承架构

    3. ObjectInputStream提供readObject()方法将数据读入为对象,而ObjectOutputStream提供writeObject()方法将对象写至目的地。

    • 字符输入类:
    1. 针对字符数据的读取,Java SE提供了 java.io.Reader类,抽象化了字符数据读入的来源;

      针对字符数据的写入,提供了java.io.Writer

      ,抽象化了数据写出的目的地。
    2. 就装饰器的作用而言,

      InputStreamReader

      System.in读入的字节数据做编码转换,而BufferedReader将编码转换后的数据做缓冲处理,以增加读取效率。
  • 第十一章 线程与并行API

    • 线程
    1. 单线线程程序就是自启动的程序从main()程序进入点开始至结束只有一个流程。多线程:在同一应用程序中,有多个流程被同时执行。
    2. 线程生命周期:调用Thread实例start()方法后,基本状态为可执行(Runnable)、被阻断(Blocked)、执行中(Running)。

    • 并行API
    1. 使用Thread建立多线程程序,必须亲自处理synchronized、对象锁定、wait()notify()notifyAll()等细节。

教材学习中的问题和解决过程

  • 问题1:在学习死结部分时,编译运行P343 DeadLockDemo.java代码,有时发生死结,有时不发生:



  • 问题1解决方案:书上的解释是这样:发生死结的原因在于,thread1在调用resource1.corportate(resource2)时,会取得r1的锁定,若此时thread2也正好调用resource2.corportate(resource1),取得r2的锁定,凑巧thread1现在打算运用传入的r2调用doSome(),理应取得r2的锁定,但锁定现在被t2拿走了,于是t1进入阻断,而t2也打算运用传入的r1调用doSome(),理应取得r1的锁定,但锁定现在是t1取走,于是t2进入等待。
  • 问题2:之前第四章的课后题中有输出斐波那契数列的题,我自己编的代码是这样:

    没有调用函数,只是用了数组。
    int[] fb=new int[num];
fb[0]=0;
fb[1]=1;
int i=0;
for(i=0;i<num;i++){
if(i>1){
fb[i]=fb[i-1]+fb[i-2];
}
  • 问题2解决方案:书上输出斐波那契数列选择的方法是递归调用函数:
static long fibonacci(long n) {
if (n <= 1) {
return n;
}
return fibonacci(n - 1) + fibonacci(n - 2);
}

代码调试中的问题和解决过程

  • 问题1:在编译P315代码时,出现了问题:

  • 问题1解决方案:发现书上省略了定义get、set的方法,补全代码如下

public String getNumber() {
return number;
} public void setNumber(String number) {
this.number = number;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
}

编译通过。

代码托管

上周考试错题总结

  • 现有:

    1. import java.util.*;

      2.
    2. Class FindStuff {

      4.public static void main (String[]args) {

      5, //insert code here

      6. c.put ("X", 123);

      7. }
    3. }

分别插入到第5行,哪几行允许代码编译?

A .Map c= new SortedMap();

B .HashMap c= new HashMap();

C .HashMap c= new Hashtable();

D .SortedMap c= new TreeMap();

E .ArrayList c= new ArrayList();

F . Map c = new LinkedHashMap();

答案:BDF


结对及互评

  • 结对:

    基于评分标准,我给本博客打分:8分。得分情况如下:

    1. 正确使用Markdown语法:加1分
    2. 模板中的要素齐全:加1分
    3. 代码调试中的问题和解决过程:加1分
    4. 感想,体会不假大空:加1分
    5. 排版精美:加1分
    6. 进度条中记录学习时间与改进情况:加1分
    7. 错题学习深入:加1分

    博客中值得学习的或问题:参考搭档的教材内容总结,对前两章的学习又有了新的理解。

    代码中值得学习的或问题:对照搭档的问题,我修改了自己的代码,程序成功编译。

  • 小组:

    基于评分标准,我给本博客打分: 9分。得分情况如下:

    1. 正确使用Markdown语法:加1分
    2. 教材学习中的问题和解决过程,:加1分
    3. 代码调试中的问题和解决过程,:加2分
    4. 本周有效代码超过300分行:加2分
    5. 排版精美的加1分
    6. 进度条中记录学习时间与改进情况的加1分
    7. 有动手写新代码的加1分

    博客中值得学习的或问题:该同学的标题写错了,应该是2016-2017学期

    基于评分标准,我给本博客打分:3分。得分情况如下:

    1. 错题学习深入:加1分
    2. 教材中的问题和解决过程:加2分

    基于评分标准,我给本博客打分:9分。得分情况如下:

    1. 正确使用Markdown语法:加1分
    2. 模板中的要素齐全:加1分
    3. 教材学习中的问题和解决过程:加1分
    4. 本周有效代码超过300分行的:加2分
    5. 排版精美:加1分
    6. 进度条中记录学习时间与改进情况:加1分
    7. 有动手写新代码:加1分
    8. 错题学习深入:加1分

    基于评分标准,我给本博客打分:8分。得分情况如下:

    1. 正确使用Markdown语法:加1分
    2. 模板中的要素齐全:加1分
    3. 教材学习中的问题和解决过程:加1分
    4. 感想,体会不假大空:加1分
    5. 排版精美:加一分
    6. 进度条中记录学习时间与改进情况:加1分
    7. 有动手写新代码:加1分
    8. 代码Commit Message规范:加1分

点评过的同学博客和代码

感悟与思考

这周正好赶上清明节放假,因为时间安排,提前两天完成任务。当然时间不够充裕,也许学习过程中有落下的部分,课后会仔细看看书。这周代码量更多了,一点一点敲确实有点繁冗枯燥,但是我相信再经过深入学习,会有一天把写代码看作跟日常吃饭睡觉一样平常。

学习进度条

代码行数(新增/累积) 博客量(新增/累积) 学习时间(新增/累积) 重要成长
第六周 1761/3365 1/1 15/92
  • 计划学习时间:17小时

  • 实际学习时间:15小时

  • 改进情况:这周没达到学习目标,本来想周六仔细看看书,但是周六白天上课,只好晚上再加班。

参考资料

20155201 2016-2017-2 《Java程序设计》第六周学习总结的更多相关文章

  1. 20155201 2016-2017-2 《Java程序设计》第九周学习总结

    20155201 2016-2017-2 <Java程序设计>第九周学习总结 教材学习内容总结 第十六章 整合数据库 JDBC全名JavaDataBaseConnecticity,是Jav ...

  2. 20155201 2016-2017-2 《Java程序设计》第一周学习总结

    20155201 2016-2017-2 <Java程序设计>第一周学习总结 教材学习内容总结 每一章的问题: 第一章 Java ME都有哪些成功的平台? 第二章 哪些情况可以使用impo ...

  3. 20155201 2016-2017-2 《Java程序设计》第二周学习总结

    20155201 2016-2017-2 <Java程序设计>第二周学习总结 教材学习内容总结 编译运行P55各种类型可储存的数值范围代码,截图: 常用格式控制符: 符号 说明 %% 表示 ...

  4. 20155313 2016-2017-2 《Java程序设计》第九周学习总结

    20155313 2016-2017-2 <Java程序设计>第九周学习总结 教材学习内容总结 第16章 JDBC(Java DataBase Connectivity)即java数据库连 ...

  5. 20145213《Java程序设计》第九周学习总结

    20145213<Java程序设计>第九周学习总结 教材学习总结 "五一"假期过得太快,就像龙卷风.没有一点点防备,就与Java博客撞个满怀.在这个普天同庆的节日里,根 ...

  6. 21045308刘昊阳 《Java程序设计》第九周学习总结

    21045308刘昊阳 <Java程序设计>第九周学习总结 教材学习内容总结 第16章 整合数据库 16.1 JDBC入门 16.1.1 JDBC简介 数据库本身是个独立运行的应用程序 撰 ...

  7. 《Java程序设计》第九周学习总结

    20145224 <Java程序设计>第九周学习总结 第十六章 整合数据库 JDBC入门 ·数据库本身是个独立运行的应用程序 ·撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的 ...

  8. 20145236 《Java程序设计》第九周学习总结

    20145236 <Java程序设计>第九周学习总结 教材学习内容总结 第十六章 整合数据库 JDBC简介 1.JDBC是java联机数据库的标准规范.它定义了一组标准类与接口,标准API ...

  9. 20155304田宜楠2006-2007-2 《Java程序设计》第一周学习总结

    20155304田宜楠2006-2007-2 <Java程序设计>第一周学习总结 教材学习内容总结 - 浏览教材,根据自己的理解每章提出一个问题 第一章 除了书上提到的开发工具还有什么适合 ...

  10. 20155303 2016-2017-2 《Java程序设计》第二周学习总结

    20155303 2016-2017-2 <Java程序设计>第二周学习总结 教材学习内容总结 『注意』 "//"为单行批注符: "/*"与&quo ...

随机推荐

  1. #Leetcode# 451. Sort Characters By Frequency

    https://leetcode.com/problems/sort-characters-by-frequency/ Given a string, sort it in decreasing or ...

  2. 远程修改VMware ESXi服务器的密码(SSH)

    1,用vSphere client登录到服务器,将SSH启用. 2,使用ssh连接工具(我用的是secureCRT)远程登录,输入passwd,键入两次新密码,OK.  

  3. [转帖]IBM POWER9 E950 and E980 Servers Launched

    IBM POWER9 E950 and E980 Servers Launched https://www.servethehome.com/ibm-power9-e950-and-e980-serv ...

  4. JAVAScript对象及初始面向对象

              javaScript对象及初始面向对象 1:内置对象 例:Date String Array 类等... 2:自定义对象 方法1:var newObj=new Object(); ...

  5. zabbix自定义监控阿里云RDS服务

    zabbix自定义监控rds zabbix通过阿里云api 自动发现.监控阿里云RDS-Mysql数据库 注意事项  脚本会收集RDS别名,  不要默认别名 不要使用中文别名(zabbix不识别)  ...

  6. selenium基础-打开百度进行搜索

    1. 安装Python 2. 安装selenium 3. 下载谷歌驱动ChromeDriver,放到Python的Scripts目录下 4. 编写代码,如下 # coding: utf-8 from ...

  7. Trailing Zeroes (I) LightOJ - 1028(求因子个数)

    题意: 给出一个N 求N有多少个别的进制的数有后导零 解析: 对于一个别的进制的数要转化为10进制 (我们暂且只分析二进制就好啦) An * 2^(n-1) + An-1 * 2^(n-2) + `` ...

  8. HNOI/AHOI2018题解

    作为一名高二老年选手来补一下我省去年的省选题. D1T1:寻宝游戏 按顺序给出\(n\)个\(m\)位的二进制数\(a_i\),再在最前方添一个\(0\), 给出\(q\)次询问,每次询问给出一个同样 ...

  9. CF1083C Max Mex 线段树

    题面 CF1083C Max Mex 题解 首先我们考虑,如果一个数x是某条路径上的mex,那么这个数要满足什么条件? 1 ~ x - 1的数都必须出现过. x必须没出现过. 现在我们要最大化x,那么 ...

  10. Android Data Binding(数据绑定)用户指南

    Android Data Binding(数据绑定)用户指南 http://www.jianshu.com/p/b1df61a4df77 https://github.com/LyndonChin/M ...