20155336 2016-2017-2《JAVA程序设计》第五周学习总结

教材学习内容总结

第八章

  • 语法与继承构架
  • 使用trycatch

    • 特点:

      • 使用trycatch语法,JVM会尝试执行try区块中的程序代码。如果有错误发生,会跳离错误发生点,执行catch区块中的代码。
      • 执行完catch区块后,没有其他程序代码,程序就会结束。
    • 注意:

      - 在java中,所有的错误都会被打包成为对象。而try、catch是在发生了InputMismatchException的错误。(实际上并不鼓励,在
      异常继承架构分析。)
  • 异常继承架构:

    • 特点:

      • 设计错误的对象都继承自java.lang.Throwable类,其有两个子类java.lang.Errorjava.lang.Exception
      • Error错误:JVM内部的严重问题。无法恢复。程序人员不用处理。
      • Exception异常:普通的问题。通过合理的处理,程序还可以回到正常执行流程。要求编程人员要进行处理。
      • RuntimeException:也叫非受检异常。这类异常是编程人员的逻辑问题。java编译器不进行强制要求处理。也就是说,这类异常在程序中,可以进行处理,也可以不处理。
      • RuntimeException:也叫受检异常。这类异常是由一些外部偶然因素所引起的。java编译器强制要求处理。也就是说,程序必须进行对这类异常的处理。
      • 如果是检受异常,可由方法的客户端依据当时调用的环境信息进行处理,必须使throws声明此方法会抛出的异常类或父亲类。
      • 如果是非受检异常,原本就可以自行选择石佛偶处理异常,也不用特别在方法上使用throws声明。
      • 如果某个方法声明会抛出Throwable或子类实例,只要不是属于Errorjava.langRuntimeException或其子类实例,就必须明确使用trycatch语法加以处理,或者用throws声明这个方法会抛出异常。
    • 注意:

       - Error与其子类实例代表严重的系统错误,其对象抛出时,基本不用处理,任其传播至JVM为止,或者最多留下日志信息。
      - 使用try、catch捕捉异常对象时也要注意,如果父类异常对象在子类异常前被捕捉,则catch子类异常对象的区块永远不会被执行。
      - catch括号中列出的异常不得有继承关系,否则会发生编译错误。
      - java是唯一采用受检异常的语言,一是为了文件化,客户端只要查阅文件,就可以知道哪些方法可能发生异常;二是提供编译程序
      信息,让编译程序能够在编译时期就检查出API客户端没有处理异常。
  • 关于抓和抛:

    • 特点:

      • 如果编译程序会抛出受检异常,无法使用trycatch处理时,必须使用throws声明此方法会抛出的异常类型或父类型,编译程序才会让你通过编译。
      • 如果抛出非受检异常,在java中的设计上认为,非受检异常是程序设计不当引发的漏洞,异常应自动往外传播。
      • 实际上,先可使用trycatch处理完部分错误后,可以使用throw抛出。
      • 重新抛出异常时,如果认为调用API的客户端应当有能力处理未处理的错误,就自定义受检异常、填入适当错误信息并重新抛出,并在方法上使用throws加以声明;如果认为调用API的客户端没有准备好就调用了方法,才会造成还有未处理的错误,就自定义非受检异常、填入适当错误信息并重新抛出。
    • 注意:

       - 先处理后抛出的时候是使用throw不是throws。
      - 在自定义类别的时候通常建议继承自Exception或其子类。
      - 在流程中要抛出的异常,也要思考一下,关键在于这是客户端可以处理的问题吗?还是客户端没有准备好前置条件就调用方法,才引发的异常?
  • 认识堆栈追踪:

    • 特点:

      • 采用直接调用异常对象的printStackTrace()
      • 善用堆栈追踪,不可有私吞异常的行为、对异常做了不当的处理。
      • 在使用throw重抛异常时,异常的追踪堆栈起点,任然是异常发生的根源。
    • 注意:

      - 如果想要让异常堆栈成为重抛异常的地方,可以使用fillInStrackTrace()方法,这个方法会重新装填异常堆栈,将起点设为重
      抛异常的地方,并返回Throwable对象。
  • 关于assert:

    - 是一种断言,预期结果与实际程序状态相同,断言成立,否则断言不成立。在java中使用-enableassertions或者是-ea自变量在执行时启动断言检查。
    - assert有两种使用方法 1. assert boollean_expression;2. assert boolean_expression:detail_pression。
    - checkGreatThanZero()是一种前置条件检查,如果程序上线之后就不需要这种检查的话,可以将之assert取代。
    - charge()方法中使用了批注来提示方法调用后的对象状态必不可义为负,不如使用assert取代。
  • 异常与资源管理:程序因错误而抛出异常时,原本的执行流程就会中端,如果程序开启了相应得资源,应该在使用完后关闭资源。

    • 特点:

      • 使用法finallytrycatch可以搭配finally区块使用。且该区块一定会被执行。
      • 可以先检查scanner是否为null,仔调用close()方法关闭Scanner
      • 尝试关闭语法资源可套用的对象,必须操作java.lang.AutoClothesable接口
      • 尝试关闭语法资源可以同时关闭两个以上的对象资源,只要中间以分号分割。
    • 注意:

      - 如果撰写的流程中线先return,而且也有`finally`区块,那`finally`区块会先执行后再将值返回。
      - 尝试自动关闭资源的对象,是撰写在`try`之后的括号中。
      - 在try括号中,越后面撰写的对象的资源会越早关闭。

第九章

  • 使用Collection收集对象
  • 了解Collection架构

    • 在使用满足各种需求的API前,需要先了解其继承与接口操作,才能了解何时采用哪个类,以及类间如何彼此合作。
    • 可以清楚地明了哪些类操作了哪个接口,继承了那个类,或哪些接口又继承自哪个接口。总之可在API文件上查询。
  • 具有索引的List

    • 特点:

      • 是一种Collection,收集对象,并以索引的方式保留收集的对象顺序。
      • java.util.ArrayList,数组在内存中会是连续的线性空间,根据索引随机存取时速度较快。
      • LinkedList在操作List接口,才用了连接结构。
      • 在每次add()对象时,会建立新的Node来保存对象,不会事先消耗内存。
    • 注意:

      ArayList如果需要调整索引顺序时,会有较差的表现,使用ArrayList操作此类并不经济。
      
      如果收集的对象经常会有变动索引的情况,也许考虑链接方式操作的List比较合适。
  • 内容不重复的set

    • 特点:

      • 在收集过程中若有相同对象,则不在重复收集。
      • Stringsplit(),可以指定切割字符串的方式。
      • 调用setsize()方法,就可以知道收集的字符串个数。
      • HashSettoString()操作,会包括收集的字符串。
      • 会使用对象hashcode()与equals()来判断对象是否相同。
    • 注意:

      如果同一个哈希桶已有对象,调用该对象equals()与要加入的对象比较,结果为false则非重复,给予收集true表示两个是重复对象,不予收集。
  • 支持队列操作的Queue

    • 如果希望收集对象时以队列的方式,收集的对象加入至尾端,取得对象是从前端。

    • 自己定义了offer()、poll()、peek()等。这些方法在操作失败的时候会返回特定的值。

    • Queue的子接口Deque定义了对队列的前端与尾端进行操作,在前端加入对象与取出对象,在尾端加入或取出对象。

    • addLast()、removeLast()、getLast()等方法。同样在其操作失败时返回特殊值。

  • 使用泛型和lambda表达式

    • 特点:

      • 不知道被收集对象的形态,在内部操作时,都是使用Object来参考被收集的对象。取回对象时也是以Object类型返回。
      • 泛型语法支持API时可以指定类或方法支持泛型类名称。
      • 在类名称旁用角括号表示支持此类泛型。
      • lambda表达式注意符号->左边是参数列,右边是方法本体。(如果是单参数又无须写出参数的类型时候()可以省略)
    • 注意:

      - 书上的例子角括号中的E只是一个类型代表。
      - 这类API没有指定类型参数实际类型,程序代码中出现类型参数的地方就会回归使用Object类型。
      - 使用lambda表达式,编译程序在推断类型时候,还可以使用泛型声明的类型作为信息来源。
  • Interable与Iterator

    • iterator()方法,定义在Collection。该方法会返回java.util.Iterator接口操作对象,这个对象包括了Collection收集的所有的对象,可以使用Iterator的hasNext()看看有无下一个对象,若有的话在使用next()取得下一对象。可使用forEach()来收集对象。
    • JDK5之后,将iterator()方法,提升至新的java.util.Iterable父接口。实际上还是调用了iterator()方法,运用返回的Iterator对象来迭代取得收集的对象。
  • Comparable与Comparator

    • 操作Comarable

      • Collectionsort()方法必须操作java.lang.Comparable接口,接口有个方法compare()方法如果a对象顺序小于b对象顺序返回小于0的值,若顺序上相等则返回0,若顺序上a大于b则返回大于0的值。
      • set的操作类之一java.util.TreeSet不仅拥有收集不重复对象的能力,还可以用红黑树方式排序收集的对象,但条件必须是Comparable
      • Queue的操作类之一java.util.PriorityQueue收集至PriorityQueue的对象,会根据指定的优先权来决定对象在对列中的顺序,优先权的告知,对象必须是Comparable或者是创建PriorityQueue时指定Comparator对象。
    • 操作Comparator
      • 接受java.util.Comparator接口操作对象,根据caompare()决定。其会传入两个对象,如果o1顺序上小于o2则返回小于0的值,顺序相等则返回0的值,顺序上o1大于o2则返回大于0的值。
  • 键值对应的Map

    • 特点:

      • 事先利用java.util.Map接口的操作对象来建立键值对应数据。
      • 常用的Map操作类为Jjava.util.HashMap与java.util.TreeMap,其继承自抽象类java.util.AbstractMap。
      • HashMap,要建立键值对应,可以使用put()方法,第一个自变量是键,第二个自变量是值。对于Map而言,键不会重复,判断是否重复根据hashCode()与equals()
      • TreeMap,键的部分将被排序,条件是作为键的对象必须操
      • Comaprable接口,或者是在创建TreeMap时指定Comparator接口对象。
      • PropertiessetProperty()指定字符串类型的键值,getProprty指定字符串类型的键,取回字符串类型的值,通常称为属性名称与属性值。
      • 可以使用getProperties()取得ProPerties实例。
      • 如果想要取得Map中所有的键,可以调用MapKeySet()返回Set对象。
      • 如果想取得Map所有的值,可以使用values()返回Collection对象。
      • 如果想同时取得Map的键与值,可以使用entrySet()方法,这会返回一个Set对象,每个元素都是Map.Entry实例,可以调用getKey()取得键,调用getValue()取得值。
    • 注意

      .properties的=左边设定属性名称,右边设定属性值。
      
       除了可载入.properties文档外,也可以使用loadfromXML()方法加载.xml文档,必须注意文件格式。

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

  • 问题1: throw 到底是什么啊?该怎么样使用? 心好累~~~T - T @-@

     - throw是抛出一个异常,这个异常可以是系统定义的异常,也可以是自定义的异常(运行时产生的异常是由系统来负责的,throw是由我
    
     们来控制的)。在一个方法体中,如果产生了异常(主动抛出或者运行时产生的异常),那么一般有两种处理方法。第一种就是try-catch
    
     捕获异常,并作处理。第二种就是不作任何处理,在方法名后面直接用throws将方法体里面的异常再往上抛出,抛到调用这个方法的地方
    
     再做捕获处理,或者也可继续往上抛,这里用的就是throws。这两种处理到最后都是要捕获处理的。所以说trow就是显示的用来抛出一个
    
     异常的,throws是方法将自己方法体内运行产生的异常或显示抛出而未处理的异常再往外抛时用的,它可以是多个。
  • 问题2: 各种异常之间存在怎样的关系?

    Error(严重系统错误) 受检异常(客户端有能力处理):Exception 非受检异常(未在恰当时机调用方法):RuntimeException

上周考试总结

  • 填空:使用JDB进行调试时单步执行命令有step和next,我们优先使用(next)
  • "hello"。substring(0,2)的值是"He"。
  • 判断:final可以用在类,方法,变量前。(OK)
  • 面向对象中,设计经验可以用(设计模式)表达

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

  • 问题1:

    package cc.openhome;
    
    import java.util.*;
    
    class Student{
    private String name;
    private String number;
    Student (String name , String number){
    this.name = name;
    this.number = number;
    } @Override
    public String toString(){
    return String.format("(%s,%s)", name,number);
    }
    } public class Students {
    public static void main(String[] args){
    Set students = new HashSet();
    students.add(new Student("Justin","B835031"));
    students.add(new Student("Monica","B835032"));
    students.add(new Student("Justin","B835031"));
    System.out.println(set);//这里
    }
    }

    根据书上,这个代码最后一行代码为System.out.println(set);但是却编译不通过显示错误。跟同学讨论后,将set改为student之后,编译就通过了!

  • 问题2:

    import java.util.HashMap;
    import java.util.Map; import static java.lang.System.out;
    public class MapKeyValue {
    public static void main(String[] args) {
    Map<String, String> map = new HashMap<>();
    map.put("one", "一");
    map.put("two", "二");
    map.put("three", "三");
    out.println("显示键");
    map.keySet().forEach(key -> out.println(key));
    out.println("显示值");
    map.values().forEach(key -> out.println(key));
    }
    }

  为什么书上显示的是二一三,而我是一二三?

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

 本次学习过程中,遇到的问题比较多,而且很复杂。一是时间很紧,二是一周两章确实真的很要命啊,这周内容这么难更没法完全掌握了。只能

 先跟着老师的思路跑了跑程序,详细的等以后再理解。每个人都会有所差别,对于编程的领悟也不同,以至于每个人的学习程度,优良中差也不

 同。但是我也在尽我最大的努力去学,现在的电子水平越来越高。类似于博客这种电子化的作业也会有很多方面来源的复制,不能仅仅凭借博客

 的好坏来判断自己的学习好坏,但是虽然我觉得我自己虽然学习java不是很优秀,但是我自己知道我在很努力学,坚持总是会有进步的。

代码托管

结对及互评

评分标准(满分10分)

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

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

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

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

    • 一周提交次数少于20次的不加分

6 其他加分: - 周五前发博客的加1分 - 感想,体会不假大空的加1分 - 排版精美的加一分 - 进度条中记录学习时间与改进情况的加1分 - 有动手写新代码的加1分 - 课后选择题有验证的加1分 - 代码Commit Message规范的加1分 - 错题学习深入的加1分 7 扣分: - 有抄袭的扣至0分 - 代码作弊的扣至0分

点评模板:

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

    • 正确使用Markdown语法
    • 模板中的要素齐全
    • 教材学习中的问题和解决过程, 一个问题加1分,一共俩
    • 代码调试中的问题和解决过程, 一个问题加1分,一共俩
    • 本周有效代码超过300分行的(加2分)
    • 感想,体会不假大空的加1分
    • 有动手写新代码的加1分
    • 代码Commit Message规范的加1分
    • 课后选择题有验证的加1分

就这10分根本不够加的~~~

点评过的同学博客和代码

学习进度条

             | 代码行数(新增/累积)| 博客量(新增/累积)|学习时间(新增/累积)|重要成长|

  --------   | :----------------:|:----------------:|:---------------:  |:-----:|

| 目标        | 5000行            |   30篇           | 400小时            |       |

| 第一周      | 200/200           |   2/2            | 20/20             |       |

| 第二周      | 300/500           |   2/4            | 18/38             |       |

| 第三周      | 500/1000          |   3/7            | 22/60             |       |

| 第四周      | 800/1300          |   4/9            | 30/90             |       |

| 第五周      | 1800/2000          |   5/9            | 45/100             |       |

参考:软件工程软件的估计为什么这么难软件工程 估计方法

参考资料

20155336 2016-2017-2《JAVA程序设计》第五周学习总结的更多相关文章

  1. 201521123025<java程序设计>第五周学习总结

    1. 本周学习总结 2. 书面作业 1.代码阅读:Child压缩包内源代码 1.1 com.parent包中Child.java文件能否编译通过?哪句会出现错误?试改正该错误.并分析输出结果. 1.2 ...

  2. Java程序设计第五周学习总结

    1. 本周学习总结 1.1 尝试使用思维导图总结有关多态与接口的知识点. 1.2 可选:使用常规方法总结其他上课内容. 2. 书面作业 **代码阅读:Child压缩包内源代码 Child.java源代 ...

  3. 20155336 2016-2017-2《JAVA程序设计》第九周学习总结

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

  4. 20155336 2016-2017-2《JAVA程序设计》第二周学习总结

    20155336 2016-2017-2 <JAVA 程序设计>第二周学习总结 教材学习内容 1: GIT版本检测 2: JAVA中基本类型 整数 字节 浮点数 字符 布尔(▲) 通过AP ...

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

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

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

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

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

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

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

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

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

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

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

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

随机推荐

  1. Scrum 5.0(继4.0)

    一,组员任务完成情况 首页设计初步完成但是需要优化界面,只能简单的输出信息和在首页进行登录.界面极其简单. 鸡汤版面设计有困难,问题在于用何种形式来管理用户的数据上传,但是经过小组间的讨论确定设计方向 ...

  2. Windows下 OpenSSL的安装与简单使用

    1. openssl的最新版本 最新版本是 openssl1.1.1 官方地址 https://www.openssl.org/source/ TLS1.3的协议(RFC8446)在2018.8.12 ...

  3. 微信小程序组件 日历

    js文件 'use strict'; let choose_year = null,   choose_month = null; const conf = {   data: {     hasEm ...

  4. python利用unittest测试框架组织测试用例的5种方法

    利用unittest测试框架可以编写测试用例,执行方式分两大类:利用main方法和利用testsuite,其中利用测试套件来组织测试用例可以有4种写法. 在此之前,先了解几个概念 TestCase:所 ...

  5. YARN的重启动问题:RM Restart/RM HA/Timeline Server/NM Restart

    ResourceManger Restart ResourceManager负责资源管理和应用的调度,是YARN的核心组件,有可能存在单点失败的问题.ResourceManager Restart是使 ...

  6. 【刷题】BZOJ 1061 [Noi2008]志愿者招募

    Description 申奥成功后,布布经过不懈努力,终于成为奥组委下属公司人力资源部门的主管.布布刚上任就遇到了一个难题:为即将启动的奥运新项目招募一批短期志愿者.经过估算,这个项目需要N 天才能完 ...

  7. Mysql分页显示

    第一部分:看一下分页的基本原理:   mysql explain SELECT * FROM message ORDER BY id DESC LIMIT 10000, 20************* ...

  8. Java之File与递归

    File类的使用和递归思想 File类 概述 文件: 存储数据 文件夹: 管理文件与文件夹 构造方法 public File(String pathname) :通过将给定的路径名字符串转换为抽象路径 ...

  9. bzoj3839【Pa2013】Działka

    题目描述 平面上有n个不重复的点.每次询问一个边平行坐标轴的矩形内(包含边界)的点组成的凸包的面积.. 输入格式 第一行两个整数k,n(1<=k<=1000000,3<=n<= ...

  10. python之旅:三元表达式、列表推导式、生成器表达式、函数递归、匿名函数、内置函数

    三元表达式 #以下是比较大小,并返回值 def max2(x,y): if x > y: return x else: return y res=max2(10,11) print(res) # ...