1. 本周学习总结
1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容。
2. 书面作业
本次PTA作业题集多线程
1. 源代码阅读:多线程程序BounceThread
1.1 BallRunnable类有什么用?为什么代码中需要调用Thread.sleep进行休眠?
- 作用:支持多线程,BallRunnable类中实现了Runnable接口
- 调用Thread.sleep会让当前运行程序休眠,这样就可以延缓程序的完成时间,看到小球运行的轨迹
1.2 Ball.java只做了两件事,这两件事分别是什么?BallComponent对象是干什么的?其内部的ArrayList有什么用?程序运行过程中,生成了几个BallComponent对象?该程序使用了多线程技术,每个小球是分别在不同的线程中进行绘制吗?
- 一是定义了小球的移动方法
<move()>
,二是定义了获取小球的大小和x,y坐标<getShape()>
- BallComponent对像实现了添加一个小球和画出一个小球这两件事
- 其内部的ArrayList是用于存放新添加的小球
- 程序运行过程中只生成了一个BallComponent对象
- 每个小球都是分别在不同的线程中运行的,因为每次 start 一次就产生一个新的线程
2. 实验总结:题集(多线程)
2.1 题目:Thread、PrintTask、Runnable与匿名内部类。
并回答:a)通过定义Runnable接口的实现类来实现多线程程序比通过继承自Thread类实现多线程程序有何好处?b) 6-1,6-3,6-11实验总结。
- 好处:只是实现了Runable接口,还可以继承其他的类。Java中可以实现多个接口,这样就可以多个线程共享同一个目标
- 实验总结:
6-1:创建一个MyThread类,包含含参构造函数和run()函数,在run()中输出0到n-1的数
6-3:使用了匿名内部类来实现Runnable接口中的run()方法,直接按要求输出
6-11:这题和6-1一样,把继承Thread类改成实现Runnable接口
2.2 使用Lambda表达式改写6-3
答:
2.3 题目:6-2(Runnable与停止线程)。回答:需要怎样才能正确地停止一个运行中的线程?
- 实验总结 6-2:
- 停止一个运行中的线程是通过定义一个用于停止线程的标志位flag,使线程能够正常退出。直接使用Thread.stop方法是不安全的
3. 互斥访问
3.1 修改TestUnSynchronizedThread.java源代码使其可以同步访问。(关键代码截图,需出现学号)
答:
4. 互斥访问与同步访问
完成题集6-4(互斥访问)与6-5(同步访问)
4.1 除了使用synchronized修饰方法实现互斥同步访问,还有什么办法可以使用synchronized实现互斥同步访问,使用代码说明(请出现相关代码及学号)?
答:可以使用synchronized的同步代码块
4.2 同步代码块与同步方法有何区别?
答:同步方法--直接在方法名前加关键字synchonrized
同步代码块--在方法内部使用关键字synchonrized
作用范围--同步方法>同步代码块
4.3 实现互斥访问的原理是什么?请使用对象锁概念并结合相应的代码块进行说明。当程序执行synchronized同步代码块或者同步方法时,线程的状态是怎么变化的?
- 原理:进程间相互排斥的使用临界资源,程序中通过给共享资源上一道锁,让规定时间内只允许一个线程(互斥)来访问共享资源
如果线程中的任务要访问的资源还没有被解锁,并且此时要执行synchronized方法或者是synchronized代码块时,就会进入Blocked状态,否则,会先回到Runnable,再等待线程调度进入Running。
4.4 Java多线程中使用什么关键字实现线程之间的通信,进而实现线程的协同工作?
答:通过synchronized 关键字、wait/notify方法、volatile关键字
5. 线程间的合作:生产者消费者问题
5.1 运行MyProducerConsumerTest.java。正常运行结果应该是仓库还剩0个货物。多运行几次,观察结果,并回答:结果正常吗?哪里不正常?为什么?
答:
可以看出运行结果不正常,出现最后货物还有剩余的情况
因为Producer和customer的存取速度不一样,Producer和customer的要求互斥同步访问的,两者不能很好的进行交互,从而出现货物剩余的状态
5.2 使用synchronized, wait, notify解决该问题(关键代码截图,需出现学号)
答:
3.码云及PTA
题目集:多线程
3.1. 码云代码提交记录
3.2 截图"多线程"PTA提交列表
3.3 统计本周完成的代码量
周次 | 总代码量 | 新增代码量 | 总文件数 | 新增文件数 |
---|---|---|---|---|
2 | 625 | 625 | 99 | 99 |
3 | 1785 | 1025 | 172 | 73 |
5 | 3634 | 1849 | 259 | 87 |
6 | 5500 | 1866 | 374 | 115 |
7 | 6073 | 573 | 421 | 47 |
8 | 6799 | 726 | 486 | 65 |
9 | 7479 | 680 | 607 | 121 |
10 | 7736 | 257 | 641 | 34 |
11 | 8674 | 938 | 814 | 173 |
12 | 8947 | 273 | 867 | 53 |