201521123037 《Java程序设计》第11周学习总结
1. 本周学习总结
1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容。
Java多线程之Executor、ExecutorService、Executors、Callable、Future与FutureTask
2. 书面作业
本次PTA作业题集多线程
1. 互斥访问与同步访问
完成题集4-4(互斥访问)与4-5(同步访问)
1.1 除了使用synchronized修饰方法实现互斥同步访问,还有什么办法实现互斥同步访问(请出现相关代码)?
使用synchronized的代码块
\\使用synchronized修饰方法
synchronized void deposit(int money){
balance+=money;
notify();
}
\\使用synchronized的代码块
void deposit(int money){
synchronized (this) {
balance+=money;
notify();
}
}
1.2 同步代码块与同步方法有何区别?
- 作用的范围不同。同步方法作用范围为整个方法而同步代码块作用范围为整个代码块在方法内部;作用范围比较小的同步锁性能更高。
- 锁对象不同。同步方法的锁对象是固定的,即this;同步代码块的锁对象是任意的对象。
1.3 实现互斥访问的原理是什么?请使用对象锁概念并结合相应的代码块进行说明。当程序执行synchronized同步代码块或者同步方法时,线程的状态是怎么变化的?
同一个时间只有一个线程获得对象锁,保证共享资源完整性。对象锁:当线程访问被同步的代码时,必须首先竞争代码所属对象上的锁(每个对象都有一把锁),否则线程将等待(阻塞),直到锁被释放。
class Counter {
private static int id = 0;
public static synchronized void addId() {//当线程获得对象锁时其他进行加法的线程不可使用该方法,避免出现错误的数据。如id=0,两个线程同时调用方法id可能为1。
id++;
}
public static void subtractId() {
synchronized (Counter.class) {//当线程获得对象锁时其他进行减法的线程不可使用该代码块,避免出现错误的数据。
id--;
}
}
public static int getId() {
return id;
}
}
线程有锁时:Running(直接获得锁)或Runnable(原本在Lock Pool,锁被释放时进行竞争,若成功获得锁,进入Runnable状态);线程无锁时:存于Lock Pool中,等待锁被释放。
1.4 Java多线程中使用什么关键字实现线程之间的通信,进而实现线程的协同工作?为什么同步访问一般都要放到synchronized方法或者代码块中?
Java多线程的通信方式有synchronized、while轮询的方式、wait/notify机制、管道通信。可以使用synchronized关键字实现线程之间的通信。同步访问外若没有synchronized关键字则会抛出IllegalMonitorStateException错误提示缺乏对象监视器,wait是释放共享锁并将该线程加入object的等待“队列”(并不是先进先出)中,notify是在该object的等待“队列”中唤醒一个等待的线程,都与synchronized关键字密切相关。synchronized可以保证共享资源完整性。
2. 交替执行
实验总结(不管有没有做出来)
在Work执行的任务次数出错,线程运行任务次数是多少次就执行多少次,不然会出现线程运行完main函数还未退出。用flag标记符进行交替执行的标记。
3. 互斥访问
3.1 修改TestUnSynchronizedThread.java
源代码使其可以同步访问。(关键代码截图,需出现学号)
3.2 进一步使用执行器改进相应代码(关键代码截图,需出现学号)
4. 线程间的合作:生产者消费者问题
4.1 运行MyProducerConsumerTest.java
。正常运行结果应该是仓库还剩0个货物。多运行几次,观察结果,并回答:结果正常吗?哪里不正常?为什么?
结果不正常。仓库剩下的货物有时为非0个。这个代码面临同步访问的问题,只有当仓库货物非空的时候才可以取货,在仓库不是满的时候才可以添加货物。代码中未出现解决这一问题的代码。
4.2 使用synchronized, wait, notify解决该问题(关键代码截图,需出现学号)
4.3 选做:使用Lock与Condition对象解决该问题。
5. 查询资料回答:什么是线程安全?(用自己的话与代码总结,写自己看的懂的作业)
线程安全指的是多个线程共享同一资源时,最后的结果等同于单线程多次操作资源则线程安全。当多线程共同进行原子操作,则结果无二义性。当多个线程进行非原子操作(超过一步的操作)很可能出现错误的结果。
public static synchronized void addId() {
id++;//id++可看作取id的值->id+1->id=id+1,所以id++为非原子操作,多个线程进行该操作可以添加对象锁解决这一问题
}
public static void subtractId() {
synchronized (Counter.class) {
id--;
}
}
6. 选做:实验总结
6.1 4-8(CountDownLatch)实验总结
执行器可以管理Thread对象,不需要我们自己对Thread进行创建和控制。有多个执行器可供选择,要根据具体情况选择合适的那个。这题指定要求线程数,则选择
newFixedThreadPool()
,CountDownLatch
能够使一个线程等待其他线程完成各自的工作后再执行,这一题可以使main函数最后执行。CountDownLatch
主要方法有countDown
和await
,之前把countDown方法放在for循环里面,PTA提示运行超时,要将countDown方法放在任务里面。
6.2 4-9(集合同步问题)实验总结
解决集合同步问题可以使用
Collections.synchronizedList(new ArrayList<Integer>())
,多个线程同时在list对象访问时线程安全。
6.3 较难:4-10(Callable),并回答为什么有Runnable了还需要Callable?实验总结。
添加任务到taskList中,并用执行器执行(invokeAll),用results接收Callable任务的返回值,最后记得将执行器关闭(shutdown)。Callable可以返回一个类型V且能够抛出checked exception,这些Runnable都无法做到。Callable和Runnable都可应用于executors,而Thread只支持Runnable。当任务执行完成后,Callable会立刻获得更新了的Future,而Runnable要自己处理。
7. 选做:使用其他方法解决题目4的生产者消费者问题。
7.1 使用BlockingQueue解决生产者消费者问题关键代码截图
7.2 说明为什么不需要显示的使用wait、notify就可以解决同步问题。这样解决相比较wait、notify有什么优点吗?
7.3 使用Condition解决生产者、消费者问题。
8. 选做:编写一段代码,证明你会使用ForkJoinPool?
3. 码云上代码提交记录
题目集:多线程(4-4到4-10)
3.1. 码云代码提交记录
在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图
3.2 截图多线程PTA提交列表
4. 选做:课外阅读
4.1 Questions and Exercises: Concurrency,学习总结。
4.2 Java多线程之Executor、ExecutorService、Executors、Callable、Future与FutureTask
4.3 Java 8 Concurrency Tutorial: Threads and Executors
201521123037 《Java程序设计》第11周学习总结的更多相关文章
- 201521123045 <java程序设计>第11周学习总结
201521123045 <java程序设计>第11周学习总结 1. 本周学习总结 2. 书面作业 2. 书面作业 Q1.1.互斥访问与同步访问完成题集4-4(互斥访问)与4-5(同步访问 ...
- 201521123027 <java程序设计>第11周学习总结
1.本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 2.书面作业 1.互斥访问与同步访问 完成题集4-4(互斥访问)与4-5(同步访问) 1.1 除了使用synchro ...
- 2018面向对象程序设计(Java)第11周学习指导及要求
2018面向对象程序设计(Java)第11周学习指导及要求 (2018.11.8-2018.11.11) 学习目标 (1) 掌握Vetor.Stack.Hashtable三个类的用途及常用API: ...
- 面向对象程序设计(JAVA) 第11周学习指导及要求
2019面向对象程序设计(Java)第11周学习指导及要求 (2019.11.8-2018.11.11) 学习目标 理解泛型概念: 掌握泛型类的定义与使用: 掌握泛型方法的声明与使用: 掌握泛型接 ...
- 20145236 《Java程序设计》第九周学习总结
20145236 <Java程序设计>第九周学习总结 教材学习内容总结 第十六章 整合数据库 JDBC简介 1.JDBC是java联机数据库的标准规范.它定义了一组标准类与接口,标准API ...
- 2018-2019 2 20175230《Java程序设计》第九周学习总结
<Java程序设计>第九周学习总结 主要内容 MySQL数据库管理系统 1.下载 2.安装 启动MySQL数据库服务器 1.启动 2.root用户 MySQL客户端管理工具 建立连接 建立 ...
- 20175209 《Java程序设计》第九周学习总结
20175209 <Java程序设计>第九周学习总结 一.教材知识点总结 有关数据库下载中存在可能出现的问题已经在博客<数据库安装和使用过程中出现的一些问题>给出了相应的解决办 ...
- 20175208 《Java程序设计》第九周学习总结
20175208 2018-2019-2 <Java程序设计>第九周学习总结 一.教材学习内容总结: 第11章 JDBC与MySQL数据库 MySQL数据库管理系统 MySQL数据库管理系 ...
- 20175202 《Java程序设计》第九周学习总结
20175202 2018-2019-2 <Java程序设计>第九周学习总结 教材知识点总结 第11章 JDBC与MySQL数据库 MySQL数据库管理系统 MySQL数据库管理系统,简称 ...
- 20175227张雪莹 2018-2019-2 《Java程序设计》第九周学习总结
20175227张雪莹 2018-2019-2 <Java程序设计>第九周学习总结 教材学习内容总结 第十一章 JDBC数据库操作 MySQL数据库管理系统 下载安装MySQL 若下载的是 ...
随机推荐
- pyhton购物程序
要求: 启动程序后,让用户输入工资,然后打印出带有序号的商品列表 用户输入商品序号购买相应的商品,或者输入 ' q ' 退出购买界面 选择商品后,检查余额是否足够,够则直接扣款,不够则提示余额不足 用 ...
- 原创:使用脚本获取本机IP地址
接来下又到了老葵花哥哥开课时间了 今天讲的有些简单 可以是涂鸦之做 也可以是无聊的发呆的杰作 我想取IP地址在大家生活中很常用 今天就给大家介绍我的六种使用脚本取IP地址的方法 很多人想问我 为什么是 ...
- c# 函数简述
函数是具有独立功能,并且能够重复使用的代码块.函数必须先声明后调用,使用函数使代码更简洁易读. 一.函数的声明与调用 1.声明格式: static 返回类型 函数名(参数类型 参数名称,参数类型 参数 ...
- 高级映射,查询缓存和与spring整合
一.高级映射 -------一对一 这里以订单查询为例,其中有一个外键为user_id,通过这个关联用户表.这里要实现的功能是这个两个表关联查询,得到订单的信息和部分user的信息.order表结构如 ...
- CSS层级关系
http://www.blogbus.com/eskimo-logs/69626018.htmlhttp://www.dmtuan.com/?p=574
- linux基础简答(1)
linux基础简答题 扇区及其4个主分区的原因 在第一个扇区中,保存着引导记录和分区信息,容量为512bytes,主引导记录(相当于MBR)446 bytes,分区表64bytes,记录每个分区信息要 ...
- Maven详解(四)------ 常用的Maven命令
这章我们讲讲几个常用的 Maven 命令.由于执行命令是在工程的基础上来的,所以我们要先创建一个 Maven 工程,具体如何创建,在上一篇博客已经介绍了:http://www.cnblogs.com/ ...
- jenkins 邮件添加附件
背景 当CI执行失败的时候,想获取到失败的用例,然后在本地调试,testNG是自带一个testng-failed.xml来记录的: 想法:尝试使用git 来push这个文件到远程仓库,然后本地pull ...
- led模组的优点和却点
插件模组 1.是指DIP封装的灯将灯脚穿过PCB板,经由过程焊接将锡灌满在灯孔内,由这种工艺做成的LED模组便是插灯模组:益处是视角年夜,亮度高,散热好:谬误舛错是像素密度小. 表贴模组 1.表贴也叫 ...
- TensorFlow框架(2)之TensorBoard详解
为了更方便 TensorFlow 程序的理解.调试与优化,TensorFlow发布了一套叫做 TensorBoard 的可视化工具.你可以用 TensorBoard 来展现你的 TensorFlow ...