1. 本周学习总结

1.1 以你喜欢的方式(思维导图或其他)归纳总结异常与多线程相关内容。

A:

2. 书面作业

本次PTA作业题集异常、多线程

1.finally

题目4-2

1.1 截图你的提交结果(出现学号)

1.2 4-2中finally中捕获异常需要注意什么?

A:只有执行过try语句块,finally语句块才会执行;无论在try块的哪个地方返回,finally块都会被执行到

2.用异常改进ArrayIntegerStack

题目4-3

2.1 截图你的提交结果(出现学号)

2.2 实验总结

A:直接用if语句判断栈满或栈空(栈满:top>=capacity;栈空:top=0;)然后根据题目要求throw出FullStackException或EmptyStackException

3.自定义异常

题目5-4

4.1 截图你的提交结果(出现学号)

4.2 自定义异常有哪几个关键点?

A:自定义异常,需要继承Exception或其子类(尝试了一下,继承Throwable也可以),这样才能被捕获到;自定义异常时:如果该异常的发生无法继续运行下去就让自定义异常继承RuntimeException;如果希望写一个需要try-catch异常类,则需要继承 Exception 类;如果你想写一个不需要try-catch异常类,那么需要继承 RuntimeException 类

4.读取文件并组装对象

实验任务书中中的题目3:读取文件并组装对象

给出关键代码(需出现你的学号)

public class ReadFile201521123100{
public static void main(String[] args) throws FileNotFoundException{
ArrayList<User> student=new ArrayList<User>();
Scanner in = null;
try{
in = new Scanner(new File("身份证号.txt"));
int count=0;
while(in.hasNextLine()){
String line = in.nextLine();
count++;
Scanner lineScanner = new Scanner(line);
lineScanner.useDelimiter(" ");
try{
String a1 = lineScanner.next();
if(a1.length() == 0 || a1.length() > 10)
{
throw new IllegalArgumentException("a1.length = " + a1.length());
} String a2 = lineScanner.next();
if(a2.length() == 0)
{
throw new IllegalArgumentException("a2.length = " + a2.length());
}
String a3 = lineScanner.next();
if(!a3.equals("男") && !a3.equals("女"))
{
throw new IllegalArgumentException("性别写的不是男女,是"+a3);
}
String a4 = lineScanner.next();
String a5 = lineScanner.next();
while(lineScanner.hasNext()){
a5 += lineScanner.next();
}
student.add(new User(a1,a2,a3,Integer.parseInt(a4),a5));
}
catch(IllegalArgumentException e)
{
System.out.println("出错的类是:"+e+"。错误在文件的第"+count+"行:"+line);
}
catch(NoSuchElementException e)
{
System.out.println("出错的类是:"+e+"。错误在文件的第"+count+"行:"+line);
}
}
}catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (in != null) {
in.close();
}
}
Collections.sort(student, (User o1, User o2) -> {
return o1.getAge() - o2.getAge();
});
for (User user : student) {
System.out.println(user.toString());
} }
}

5.学会使用Eclipse进行调试

观看相关调试视频

5.1 简述使用Eclipse进行调试需要几步?

A:在正确的地方设置断点;启动调试模式;Eclipse有一个专门的debug perspective,专门用于调试;查看状态值

5.2 调试时F5, F6, F7快键键各有什么不同?什么情况该使用哪个快捷键?

A:F5:step into;F6:step over,跳过;F7:step return,跳出;F8:resume,恢复运行直到碰到下一个断点

5.3 除了Eclipse的调试器,你还使用什么方法调试程序?

A:一般使用System.out.println输出值来调试。

6.题集多线程

6.1 程序填空3-1、3-2。(截图提交结果,出现你的学号)

6.2 函数4-1(Thread)、4-2(Runnable)(截图提交结果,出现你的学号)

6.3 函数4-3(Runnable与匿名内部类)(截图提交结果,出现你的学号),并使用Labmda表达式改写。

6.4 实验总结

A:3-1:设置t1为守护线程即可

3-2:t1.start(),之后用while(t1.isAlive()){}或者使用t1.join()语句确认其结束

4-1:重写run()方法,循环输出0 到 n - 1,结束之后输出该线程的名称

4-2:将检查过的word置为空,并在判断word与alien的时候多加一个判空的条件;在stopMe方法中使用Thread.yield();来阻止线程运行

4-3:学习了一些Thread的函数

7.源代码阅读:多线程程序BounceThread

7.1 哪个类是支持多线程的类,它实现了什么接口。这个类做了些什么?

A:BallRunnable是支持多线程的类,它实现了Runnable接口,生成小球的位置移动,移动之后,对界面进行重画,并睡眠一段时间

7.2 Ball.java这个程序只做了两件事,这两件事分别是什么?

A:定义了move方法:移动球到下一个位置,如果它击中一个边缘,使其反向运动;定义了getShape方法:获得当前位置球的形状

7.3 BallComponent也只做了两件事,这两件事分别是什么?

A:add(Ball b)加小球和paintComponent(Graphics g)画小球

7.4 BounceThread中,什么时候启动了新线程?

A:点击addButton按钮的时候会添加一个小球,启动一个新线程。

7.5 这个程序是如何实现?一个大致的执行流程是什么?

A:建立一个图像界面,然后让小球显示出来,接着点击按钮可以看到小球移动,再点击就多出一个移动的球。就是一个球运动的过

8.购物车系统中的多线程

8.1 购物车系统中可能存在哪些多线程问题?

A::有多个Frame就有多个线程,有几个使用者就有几个多线程

3. 码云上代码提交记录

3.1. 码云代码提交记录

在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图

201521123100《Java程序设计》 第10周学习总结的更多相关文章

  1. 2018面向对象程序设计(Java)第10周学习指导及要求

    2018面向对象程序设计(Java)第10周学习指导及要求(2018.11.1-2018.11.4)  学习目标 理解泛型概念: 掌握泛型类的定义与使用: 掌握泛型方法的声明与使用: 掌握泛型接口的定 ...

  2. 面向对象程序设计(JAVA) 第10周学习指导及要求

    2019面向对象程序设计(Java)第10周学习指导及要求 (2019.11.1-2019.11.4)   学习目标 1.掌握java异常处理技术: 2.了解断言的用法: 3.了解日志的用途: 4.掌 ...

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

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

  4. 20145213《Java程序设计》第二周学习总结

    20145213<Java程序设计>第二周学习总结 教材学习内容总结 本周娄老师给的任务是学习教材的第三章--基础语法.其实我觉得还蛮轻松的,因为在翻开厚重的书本,一股熟悉的气息扑面而来, ...

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

    20145213<Java程序设计>第一周学习总结 教材学习内容总结 期待了一个寒假,终于见识到了神秘的娄老师和他的Java课.虽说算不上金风玉露一相逢,没有胜却人间无数也是情理之中,但娄 ...

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

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

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

    20145218 <Java程序设计>第一周学习总结 教材学习内容总结 今天下午看了Java学习的视频,感觉很是新奇,之前觉得Java学起来是艰难枯燥的,但通过第一章的学习觉得如果自己可以 ...

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

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

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

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

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

    20155304田宜楠 2006-2007-2 <Java程序设计>第二周学习总结 教材学习内容总结 一.类型与变量 1.类型 整数: 可细分为为short整数(占2字节),int整数(占 ...

随机推荐

  1. Oracle SQL优化[转]

    Oracle SQL优化 1. 选用适合的ORACLE优化器 ORACLE的优化器共有3种: a. RULE (基于规则) b. COST (基于成本) c. CHOOSE (选择性) 设置缺省的优化 ...

  2. dom作业

    <body> <select size="7" style="width: 200px;" id="slt"> &l ...

  3. XtraBackup应用说明(支持TokuDB)

    背景: 关于物理备份工具xtrabackup的一些说明可以先看之前写过的文章说明:XtraBackup 安装使用和xtrabackup 使用说明(续),本篇文章将介绍xtrabackup在使用中的注意 ...

  4. [js高手之路] 设计模式系列课程 - jQuery的链式调用与灵活的构造函数

    一.我们从一个简单的构造函数+原型程序开始 var G = function(){}; G.prototype = { length : 5, size : function(){ return th ...

  5. 【学习笔记】深入理解超时调用(setTimeout)和间歇调用(setInterval)

    超时调用(setTimeout):在指定的毫秒数后调用函数或计算表达式. setTimeout(func, 1000); // func执行的函数,1000毫秒 间歇调用(setInterval):按 ...

  6. Android开发 去掉标题栏方法 摘记

    1.用代码里实现 提示:这句代码要写在Activity中的setContentView()方法前面. 2.在清单文件(Androidmanifest.xml)里面实现   android:theme= ...

  7. mapper.xml是怎样实现Dao层接口

    上午写了一个简单的 从xml读取信息实例化一个Bean对象.下午就开始想mybatis是怎么通过xml文件来实现dao层接口的,一开始想直接用Class.forName(String name)然后调 ...

  8. 201671010121 2016-2017-2《java程序设计》第一周学习总结

    之前学了些C语言,学的也不是太懂,还算能读懂一些简答的代码吧,我觉得这就是进步.刚步入大二,在计算机这个专业里不刻苦是不行的.但是,到我拿到Java书的时候,真心是吓住我了,好厚的一本书啊,不过在老师 ...

  9. [Caffe]使用经验积累

    Caffe使用经验积累 本贴记录Caffe编译好了,使用过程的常用命令与常见错误解决方式.如果对编译过程还存在问题,请参考史上最全的caffe安装过程配置Caffe环境. 1 使用方法 训练网络 xx ...

  10. 【算法设计与分析基础】25、单起点最短路径的dijkstra算法

    首先看看这换个数据图 邻接矩阵 dijkstra算法的寻找最短路径的核心就是对于这个节点的数据结构的设计 1.节点中保存有已经加入最短路径的集合中到当前节点的最短路径的节点 2.从起点经过或者不经过 ...