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 若下载的是 ...
随机推荐
- ORACLE_RESETLOGS浅析[转]
alter database open resetlogs 这个命令我想大家都很熟悉了,那有没有想过这个resetlogs选项为什么要用?什么时候用?它的原理机制是什么?他都起哪些作用? 我们都知道数 ...
- C++跨平台使用(安卓,iso等)
1 C#调用C++接口总结 http://www.cnblogs.com/xtblog/p/5729541.html 2 java调用C++接口 http://www.cnblogs.com/liul ...
- 使用bootstrap网格系统自适应盒子宽度时保持所有盒子高度一致。
使用了bootstrap网格系统的好处是很容易便实现了响应式布局,盒子可以根据设置的样式,随着屏幕的大小改变而自动改变宽度,但是也存在一个问题,那就是盒子的高度是由盒子的内容决定的,如果盒子里的内容不 ...
- 立即表达式的多种写法与注意点以及in操作符的作用
立即表达式,在javascript中非常常见, 采用立即表达式可以形成一个局部作用域, 常配合闭包实现模块化编程等其他用途,接下来我们看看,在大多数的框架中,立即表达式都有哪些写法,以及需要注意的点, ...
- vector中删除第k个元素的巧妙方法
假设我们定义了一个vector如下: vector<int> v;v.push_back(1);...v.push_back(255); 如果要删除第k个元素的话,应该这样写: (1)如果 ...
- Linux下自动备份MySQL数据库并上传到远程FTP服务器
Linux下自动备份MySQL数据库并上传到远程FTP服务器且删除指定日期前的备份Shell脚本 说明: 1.备份MySQL数据库存放目录/var/lib/mysql下面的xshelldata数据库 ...
- 7.28.2 static关键字(静态和成员)
成员是对象级别的,访问成员必须用"引用.",如果用"类名."访问会报错!如果用空引用访问成员则会发生控空指针异常! 静态是类级别的,访问静态必须用类" ...
- 匿名委托与Lambda表达式
通过使用匿名委托(匿名方法),使编程变得更加灵活,有关委托与匿名委托请参考我的前一篇Blog<委托与匿名委托>. 继续之前示例,代码如下: static void Main(string[ ...
- web安全:QQ号快速登录漏洞及被盗原理
为什么你什么都没干,但QQ空间中却发了很多小广告?也许你的QQ账号已经被盗.本文将讲解一个QQ的快速登录的漏洞. 我前阵子在论坛上看到一个QQ的快速登录的漏洞,觉得非常不错,所以把部分原文给转到园子来 ...
- 【Java学习笔记之三十二】浅谈Java中throw与throws的用法及异常抛出处理机制剖析
异常处理机制 异常处理是对可能出现的异常进行处理,以防止程序遇到异常时被卡死,处于一直等待,或死循环. 异常有两个过程,一个是抛出异常:一个是捕捉异常. 抛出异常 抛出异常有三种形式,一是throw, ...
