1. 本周学习总结
1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容。
2. 书面作业
本次PTA作业题集多线程
1. 源代码阅读:多线程程序BounceThread
1.1 BallRunnable类有什么用?为什么代码中需要调用Thread.sleep进行休眠?
答:BallRunnable类实现了Runnable接口。调用Thread.sleep是为了让正在执行的线程休眠一段时间,不消耗CPU资源
1.2 Ball.java只做了两件事,这两件事分别是什么?BallComponent对象是干什么的?其内部的ArrayList有什么用?程序运行过程中,生成了几个BallComponent对象?该程序使用了多线程技术,每个小球是分别在不同的线程中进行绘制吗?
答:两件事:1)定义move()函数,实现小球移动。2)定义getshape()函数,确定当前位置小球的形状。
BallComponent对象:改对象用于——1.添加小球;2绘制每个位置的小球;
ArrayList:用于记录已添加的小球;
程序运行过程中,生成了一个BallComponent对象。
该程序,每个小球是分别在不同的线程中进行绘制。
2. 实验总结:题集(多线程)
2.1 题目:Thread、PrintTask、Runnable与匿名内部类。
并回答:a)通过定义Runnable接口的实现类来实现多线程程序比通过继承自Thread类实现多线程程序有何好处?b) 6-1,6-3,6-11实验总结。
答:Runnable接口的实现可以避免继承方法的局限(一个类可以有多个接口,但是只能继承一个父类)
- 实验总结:
- 6-1:编写MyThread类继承Thread;遍历输出0到n-1;最后输出按格式输出'System.out.println(Thread.currentThread().getName()+" "+isAlive())';
- 6-3:此题主要是依次输出主线程名、线程t1线程名、线程t1实现的所有接口。
- 6-11:此题主要使用Runanable接口实现多线程。
2.2 使用Lambda表达式改写6-3
2.3 题目:6-2(Runnable与停止线程)。回答:需要怎样才能正确地停止一个运行中的线程?
答:stop()方法可以用于强制停止线程。正确方法应该是自行编写Stopme()方法,令flag=true,来正确安全的停止线程。
3. 互斥访问
3.1 修改TestUnSynchronizedThread.java源代码使其可以同步访问。(关键代码截图,需出现学号)
4. 互斥访问与同步访问
完成题集6-4(互斥访问)与6-5(同步访问)
4.1 除了使用synchronized修饰方法实现互斥同步访问,还有什么办法可以使用synchronized实现互斥同步访问,使用代码说明(请出现相关代码及学号)?
答:
4.2 同步代码块与同步方法有何区别?
答:同步代码快需要锁定对象,同步方法锁定整个方法。同步块的作用范围小,效率更高。
4.3 实现互斥访问的原理是什么?请使用对象锁概念并结合相应的代码块进行说明。当程序执行synchronized同步代码块或者同步方法时,线程的状态是怎么变化的?
答:原理:实现互斥访问的原理是程序通过给共享资源上锁 让给定时间内只允许一个线程来访问共享资源。
如图所示,第二行运行结果与第一行间隔5S,这体现了互斥。因为synchronzied,第二个线程需要等待第一个线程运行结束后才可以访问run方法。
4.4 Java多线程中使用什么关键字实现线程之间的通信,进而实现线程的协同工作?
答:synchronized
wait
/notify
volatile
5. 线程间的合作:生产者消费者问题
5.1 运行MyProducerConsumerTest.java。正常运行结果应该是仓库还剩0个货物。多运行几次,观察结果,并回答:结果正常吗?哪里不正常?为什么?
答:运行结果如下图。其结果是不正常的,正常的结果应使得仓库无货无法取货。其原因是生产者、消费者的速度不同。
5.2 使用synchronized, wait, notify解决该问题(关键代码截图,需出现学号)
答:仅已添加货物为例。
6. 面向对象设计作业-图书馆管理系统
6.1 系统的功能模块表格,表格中体现出每个模块的负责人。
6.2 运行视频
6.3 讲解自己负责的模块,并粘贴自己负责模块的关键代码(出现学号及姓名)。
3.码云及PTA
题目集:多线程
3.1. 码云代码提交记录
3.2 截图"多线程"PTA提交列表
需要有两张图(1. 排名图。2.PTA提交列表图)
3.3 统计本周完成的代码量
需要将每周的代码统计情况融合到一张表中。
周次 | 总代码量 | 新增代码量 | 总文件数 | 新增文件数 |
---|---|---|---|---|
1 | 0 | 0 | 0 | 0 |
2 | 0 | 0 | 0 | 0 |
3 | 639 | 639 | 16 | 16 |
4 | 639 | 0 | 16 | 0 |
5 | 841 | 202 | 19 | 3 |
6 | 1075 | 234 | 23 | 4 |
7 | 1419 | 344 | 27 | 4 |
8 | 2028 | 609 | 33 | 6 |
9 | 2194 | 166 | 37 | 4 |
10 | 2625 | 431 | 41 | 4 |
11 | 2778 | 153 | 48 | 7 |
12 | 3251 | 473 | 51 | 3 |