201621123028《Java程序设计》第11周学习总结
作业11-多线程
1.本周学习总结
2. 书面作业
本次PTA作业题集多线程
1. 源代码阅读:多线程程序BounceThread
1.1 BallRunnable类有什么用?为什么代码中需要调用Thread.sleep
进行休眠?
BallRunnable类实现了Runnable接口,里面的方法我们可以通过点一次出现一个小球的移动。调用Thread.sleep
进行休眠的功能是让小球的速度变慢。可以看见轨迹。
1.2 Ball.java只做了两件事,这两件事分别是什么?BallComponent对象是干什么的?其内部的ArrayList有什么用?程序运行过程中,生成了几个BallComponent对象?该程序使用了多线程技术,每个小球是分别在不同的线程中进行绘制吗?
1.move方法,让小球有规律移动。2.获取小球的坐标
BallComponent对象是实现对小球进行添加和让它出现在界面中。
其内部的ArrayList可以动态存储小球。
程序运行过程中,生成了1个BallComponent对象.每个小球是分别在不同的线程中进行绘制的。
1.3 选做:程序改写:程序运行时,每个小球都是从固定位置出发。如何改写该程序,使得当点击start时,每个小球可以从不同位置出发、以不同的步进移动?
使用随机数的办法让每个小球可以从不同位置出发、以不同的步进移动
2. 实验总结:题集(多线程)
2.1 题目:Thread、PrintTask、Runnable与匿名内部类。并回答:a)通过定义Runnable接口的实现类来实现多线程程序比通过继承自Thread类实现多线程程序有何好处?b) 6-1,6-3,6-11实验总结。
a)好处是显然的,我们知道一个类只能是继承一个类,但是一个类能实现多个接口,对于程序要实现一些复杂功能的时候,继承Thread类很难实现。如果定义Runnable接口的实现类可以避免单继承所带来的局限性。
b)6-1:难度不大,需要一个构造函数public MyThread(int parseInt)
,在public void run()
方法中就是一个for循环输出。
6-3:new Thread(new Runnable()
中用run方法分别输出主线程名、线程t1的线程名、线程t1所实现的所有接口。
6-11:这题和6-1相似,不一样的地方是,6-1是继承Thread然后覆盖其中的run()方法来实现,而本题是编写了PrintTask类实现Runnable接口来实现的。可以参考6-1做出来。
2.2 使用Lambda表达式改写6-3
2.3 题目:6-2(Runnable与停止线程)。回答:需要怎样才能正确地停止一个运行中的线程?
可以通过调用线程的stop()方法来实现终止该线程,但是这个方法问题很多,就是让线程强行中断,可能导致代码逻辑的不完整。所以不用,现在可以使用boolean标志来使线程中的run()方法退出,这个方法的好处是它让线程跑结束,然后再终止这个线程。
3. 互斥访问
3.1 修改TestUnSynchronizedThread.java源代码使其可以同步访问。(关键代码截图,需出现学号)
4. 互斥访问与同步访问
完成题集6-4(互斥访问)与6-5(同步访问)
4.1 除了使用synchronized修饰方法实现互斥同步访问,还有什么办法可以使用synchronized实现互斥同步访问,使用代码说明(请出现相关代码及学号)?
可以通过synchronized关键字来声明synchronized块
4.2 同步代码块与同步方法有何区别?
同步方法就是只有调用到这个方法的时候这个锁才会发挥作用,就是这个锁保护了整个方法。
同步代码块的话是被修饰的那个语句块会自动被加上内置锁,从而实现了同步的功能。
4.3 实现互斥访问的原理是什么?请使用对象锁概念并结合相应的代码块进行说明。当程序执行synchronized同步代码块或者同步方法时,线程的状态是怎么变化的?
对共享资源访问的方法或代码块之前加上synchronized关键字,如果线程没有获得对象锁时,之后的代码不执行,线程进入Lock Pool。这样实现了能被一个一个访问。
如图中,increase()
函数中用了synchronized
修饰,在main中先t1启动,等t1线程结束后,t2才能访问i++
,直到j=1000000时结束加和。所以这个结果应该是2000000.
4.4 Java多线程中使用什么关键字实现线程之间的通信,进而实现线程的协同工作?
- synchronized关键字
- wait () 和notify()/notifyAll()方法
5. 线程间的合作:生产者消费者问题
5.1 运行MyProducerConsumerTest.java。正常运行结果应该是仓库还剩0个货物。多运行几次,观察结果,并回答:结果正常吗?哪里不正常?为什么?
不正常,按理是仓库没货物了,但是运行结果是仓库还剩下19个货物。可见放货物的速度比拿货物的速度来的大,导致货物有剩。
5.2 使用synchronized, wait, notify
解决该问题(关键代码截图,需出现学号)
6. 面向对象设计作业-图书馆管理系统
6.1 系统的功能模块表格,表格中体现出每个模块的负责人。
学生 | 负责任务 |
---|---|
林志伟 | 用户借书还书信息 |
占恒 | 用户注册登录 |
郑玉波 | 图书检索 |
6.2 运行视频
6.3 讲解自己负责的模块,并粘贴自己负责模块的关键代码(出现学号及姓名)。
采用动态链表的搜索方法判断用户是否已经注册过。
3.码云及PTA
题目集:多线程
3.1. 码云代码提交记录
- 在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图
- 必须出现几个要素:提交日期-用户名(姓名与学号)-不提交说明
3.2 截图"多线程"PTA提交列表
需要有两张图(1. 排名图。2.PTA提交列表图)
3.3 统计本周完成的代码量
需要将每周的代码统计情况融合到一张表中。
周次 | 总代码量 | 新增代码量 | 总文件数 | 新增文件数 |
---|---|---|---|---|
1 | 0 | 0 | 0 | 0 |
2 | 571 | 571 | 19 | 19 |
3 | 1029 | 458 | 20 | 1 |
4 | 1029 | 0 | 20 | 0 |
5 | 1359 | 330 | 25 | 5 |
6 | 2061 | 702 | 35 | 10 |
7 | 2653 | 592 | 42 | 7 |
8 | 3315 | 662 | 48 | 6 |
9 | 4171 | 856 | 54 | 6 |
10 | 4569 | 398 | 59 | 5 |
11 | 4887 | 318 | 70 | 11 |
12 | 5506 | 619 | 78 | 8 |