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 若下载的是 ...
随机推荐
- Maven注意事项
Maven好处: 1.依赖管理:对jar包统一管理 2.项目构建:项目编码完成后,对项目进行编译.测试.打包.部署,实现项目一键发布1.配置环境变量 注意:maven工具必须有jdk环境.并且: ...
- webpack的四个核心概念介绍
前言 webpack 是一个当下最流行的前端资源的模块打包器.当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后 ...
- 剑指OFFER的跳台阶问题
一只青蛙一次可以跳上1级台阶,也可以跳上2级.求该青蛙跳上一个n级的台阶总共有多少种跳法. (斐波那契数列的变形) F(1)=1;F(2)=2; F(n)=F(n-1)+F(n-2); class S ...
- V8 内存控制
V8主要将内存分为:新生代 和 老生代. 1.新生代 新生代中的对象为存活时间短的对象. 它将堆内存一分为二,每一部分空间称为 semispace,其中一个处于使用状态(from 空间),另一个处于闲 ...
- install ubuntu16.04
1.添加分区 添加驱动目录/boot,ext4文件系统 ,给200m够了,图中2G多了,勾选格式化 添加 根目录/ 25G ,ext4文件系统,勾选格式化 添加 家目录 /home ,30G ...
- 获取当前页面URL信息
文章链接:http://www.cnblogs.com/hongmaju/p/5510988.html 查看信息可以在控制台输出(tab或者右移补全): 如:document.URL window. ...
- 安装node/npm/webpack步骤
nodejs软件的下载地址:https://nodejs.org/en/ 1.只要安装好了nodejs,就自动安装好了npm包. 2.在cmd中通过命令node -version查看是否安装好node ...
- Spring MVC请求执行流程
学习Spring MVC时间有点长了,但是最近打算找工作,需要重新了解下,所以又去温故知新了.Spring MVC就是用来写web的框架,简化你写web的一些不必要的流程,让程序员能专注于业务逻辑也就 ...
- 又一流氓推广Microsoft Edge,我勒个去
最新的Windows10 的升级也是醉了,不得不吐槽一个非常流氓的浏览器推广:Microsoft Edge(这小婊砸). 为了将之前的历史包袱IE干掉,这次微软也是蛮拼的,直接把IE从电脑里干掉了,你 ...
- Spring Web MVC(三)之注解
[toc] spring web mvc 基于注解的优化 我写的注解是按照spring web的部件分类写的,这样的话比较方便查看,大家感觉有用的话可以分享个别人,希望对对更多的人有帮助.毕竟零基础开 ...