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

教材学习内容总结

  1. 就目前来说,即使标注为GMT(无论是文件说明,或者是API的日期时间字符串描述),实际上谈到时间指的是UTC时间。
  2. 如果想要取得系统时间,方法之一是使用System.currentTimeMillis()方法,返回的是long类型整数。
  3. Date有两个构造函数可以使用,一个可使用epoch毫秒数构建,另一个为无自变量构造函数,内部亦是使用System.currentTimeMillis()取得毫秒数,调用getTime()可取得内部保存的epoch毫秒数值。
  4. DateFormat是个抽象类,其操作类是java.text.SimpleDateFormat,可以直接构建SimpleDateFormat实例,或是使用DateFormat的getDateInstance()getTimeInstance()、getDateTimeInstance等静态方法,用较简便方式按不同需求取得SimpleDateFormat实例。
  5. 使用Calendar时若没有使用时区信息,则会使用默认时区。可以使用java.util.TimeZone的getDefault()来取得默认时区信息。
  6. 对于时间计量,新时间与日期API以类Duration来定义,可用于计量天、时、分、秒的时间差,精度调整可以达纳秒等级,而秒的最大值可以是long类型可保存值。对于年、月、星期、日的日期差,使用Period类定义。

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

  • 问题1:Java有哪些处理日期时间常用方法:
  • 问题1解决方案:
  1. java.util.Calendar
  2. java.util.Date
  3. java.sql.Date
  4. java.util.GregorianCalendar
  5. java.text.DateFormat
  • 问题2:如何进行日期的比较

  • 问题2解决方案:

    Java使用以下三种方法来比较两个日期:

    1.使用 getTime()方法获取两个日期(自1970年1月1日经历的毫秒数值),然后比较这两个值。

    2.使用方法 before(),after() 和 equals()。例如,一个月的12号比18号早,则 new Date(99, 2, 12).before(new Date (99, 2, 18)) 返回true。

    3 .使用compareTo()方法,它是由 Comparable接口定义的,Date 类实现了这个接口。

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

  • 问题1:两个string类型的日期比较大小:
  • 问题1解决方案:
public static int compare_date(String DATE1, String DATE2) {
2 DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
3 try {
4 Date dt1 = df.parse(DATE1);
5 Date dt2 = df.parse(DATE2);
6 if (dt1.getTime() > dt2.getTime()) {
7 System.out.println("dt1 在dt2前");
8 return 1;
9 } else if (dt1.getTime() < dt2.getTime()) {
10 System.out.println("dt1在dt2后");
11 return -1;
12 } else {
13 return 0;
14 }
15 } catch (Exception exception) {
16 exception.printStackTrace();
17 }
18 return 0;
19 }
  • 问题2:如何计算两段日期的重合日期?
  • 问题2解决方案:
/**
2 * 计算两段日期的重合日期
3 * @param str1 开始日期1
4 * @param str2 结束日期1
5 * @param str3 开始日期2
6 * @param str4 结束日期2
7 * @return
8 * @throws Exception
9 */
10 public static Map<String,Object> comparisonRQ(String str1, String str2, String str3,
11 String str4) throws Exception {
12 String mesg = "";
13 DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
14 String startdate = "";
15 String enddate = "";
16 try {
17 Date dt1 = df.parse(str1);
18 Date dt2 = df.parse(str2);
19 Date dt3 = df.parse(str3);
20 Date dt4 = df.parse(str4);
21 if (dt1.getTime()<=dt3.getTime()&&dt3.getTime()<=dt2.getTime()&&dt2.getTime()<=dt4.getTime()) {
22 mesg = "f";//重合
23 startdate = str3;
24 enddate = str2;
25 }
26 if (dt1.getTime()>=dt3.getTime()&&dt3.getTime()<=dt2.getTime()&&dt2.getTime()<=dt4.getTime()) {
27 mesg = "f";//重合
28 startdate = str1;
29 enddate = str2;
30 }
31
32 if (dt3.getTime()<=dt1.getTime()&&dt1.getTime()<=dt4.getTime()&&dt4.getTime()<=dt2.getTime()) {
33 mesg = "f";//重合
34 startdate = str1;
35 enddate = str4;
36 }
37 if (dt3.getTime()>=dt1.getTime()&&dt1.getTime()<=dt4.getTime()&&dt4.getTime()<=dt2.getTime()) {
38 mesg = "f";//重合
39 startdate = str3;
40 enddate = str4;
41 }
42
43 System.out.println(startdate+"----"+enddate);
44
45
46 }catch (ParseException e) {
47 e.printStackTrace();
48 throw new ParseException(e.getMessage(), 0);
49 }catch(Exception e){
50 e.printStackTrace();
51 throw new Exception(e);
52 }
53 Map<String,Object> map = new HashMap<String,Object>();
54 map.put("startdate", startdate);
55 map.put("enddate", enddate);
56 return map;
57 }

代码托管



上周考试错题总结

  1. 下面哪条命令可以把 f1.txt 复制为 f2.txt ?(A,C)

    A .

    cp f1.txt f2.txt

    B .

    copy f1.txt f2.txt

    C .

    cat f1.txt > f2.tx

    D .

    cp f1.txt | f2.tx

    E .

    copy f1.txt | f2.tx

2.调用线程的interrupt()方法 ,会抛出()异常对象?(D,E)

A .

IOException

B .

IllegalStateException

C .

RuntimeException

D .

InterruptedException

E .

SecurityException

  1. Given an instance of a Stream, s, and a Collection, c, which are valid ways of creating a parallel stream? (Choose all that apply.)

    给定一个Stream的实例s, 一个Collection的实例c, 下面哪些选项可以创建一个并行流?(AD)

A .

new ParallelStream(s)

B .

c.parallel()

C .

s.parallelStream()

D .

c.parallelStream()

E .

new ParallelStream(c)

F .

s.parallel()

结对及互评

评分标准

  1. 正确使用Markdown语法(加1分):

    • 不使用Markdown不加分
    • 有语法错误的不加分(链接打不开,表格不对,列表不正确...)
    • 排版混乱的不加分
  2. 模板中的要素齐全(加1分)

    • 缺少“教材学习中的问题和解决过程”的不加分
    • 缺少“代码调试中的问题和解决过程”的不加分
    • 代码托管不能打开的不加分
    • 缺少“结对及互评”的不能打开的不加分
    • 缺少“上周考试错题总结”的不能加分
    • 缺少“进度条”的不能加分
    • 缺少“参考资料”的不能加分
  3. 教材学习中的问题和解决过程, 一个问题加1分

  4. 代码调试中的问题和解决过程, 一个问题加1分

  5. 本周有效代码超过300分行的(加2分)

    • 一周提交次数少于20次的不加分
  6. 其他加分:

    • 周五前发博客的加1分
    • 感想,体会不假大空的加1分
    • 排版精美的加一分
    • 进度条中记录学习时间与改进情况的加1分
    • 有动手写新代码的加1分
    • 课后选择题有验证的加1分
    • 代码Commit Message规范的加1分
    • 错题学习深入的加1分
    • 点评认真,能指出博客和代码中的问题的加1分
    • 结对学习情况真实可信的加1分
  7. 扣分:

    • 有抄袭的扣至0分
    • 代码作弊的扣至0分
    • 迟交作业的扣至0分

点评模板:

  • 博客中值得学习的或问题:

    • xxx
    • xxx
    • ...
  • 代码中值得学习的或问题:

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

  • 参考示例

点评过的同学博客和代码

其他(感悟、思考等,可选)

这周第一次做实验,感觉对于知识点的把握还是得靠自己按照自己思路编写程序,因为这样就可以看到自己哪里不会哪里欠缺了。

学习进度条

代码行数(新增/累积) 博客量(新增/累积) 学习时间(新增/累积) 重要成长
目标 5000行 30篇 400小时
第一周 15/15 1/4 12/12
第二周 140/155 1/5 18/30
第三周 677/817 1/ 6 20/50
第四周 583/1400 1/7 20/70
第五周 540/1940 1/8 22/92
第六周 362/2302 1/9 13/105
第七周 851/3152 2/10 13/120
  • 计划学习时间:12小时

  • 实际学习时间:15小时

  • 改进情况:

(有空多看看现代软件工程 课件

软件工程师能力自我评价表
)

参考资料

最新文章

  1. Windows批处理:自动部署常用软件(静默安装)
  2. 简例 一次执行多条mysql insert语句
  3. UVALive 4329 Ping pong(树状数组)
  4. day14---html基础
  5. BZOJ 4245: [ONTAK2015]OR-XOR
  6. SSIS Error The Execute method on the task returned error code 0x80131621
  7. python socket 常见方法及 简单服务/客户端
  8. Entity Framework 乐观并发控制
  9. Mac OS X 快捷键
  10. retrifit
  11. java实现的MySQL自动备份和还原(struts2+Hibernate)---兼容 window+Linux
  12. Mac查看端口占用情况
  13. 1088-Gnome Sequencing
  14. [Entity Framework]获取部分字段的查询
  15. -_-#【jQuery插件】Colorpicker 颜色选择器
  16. MVC模式实现登录以及增删改查之登录(一)
  17. 各种 SVG 制作单选和多选框动画
  18. LNMP安装后MYSQL数据库无法远程访问解决
  19. prometeus, grafana部署以及监控mysql
  20. ICSharpCode.SharpZipLib 开源压缩库使用示例

热门文章

  1. java保留两位小数4种方法(转载)
  2. 如何基于 K8S 多租能力构建 Serverless Container
  3. Intellij IDEA 文件修改提示星号
  4. Java单元测试框架 JUnit
  5. mysql左外连接
  6. Beta版本冲刺(六)
  7. node之post提交上传
  8. Postgresql 简单安装过程. Study From https://www.cnblogs.com/stulzq/p/7766409.html
  9. [转帖] Oracle数据库 通过触发器 限制登录ip
  10. SQLSERVER 查看操作系统内存