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 若下载的是 ...
随机推荐
- python学习之核心数据类型
python核心数据类型 对象类型 例子 数字 1234,-345 字符串 'spam' 列表 [1,3,'ds'] 元组 (1,'spam',6) 字典 {'name':'lili','age':1 ...
- 关于CGI:Tomcat、PHP、Perl、Python和FastCGI之间的关系
如前文所述,Web服务器是一个很简单的东西,并不负责动态网页的构建,只能转发静态网页.同时Apache也说,他能支持perl,生成动态网页.这个支持perl,其实是apache越位了,做了一件额外的事 ...
- Mac terminal commands
Mac terminal commands 1.install_name_tool修改dylib安装名称的命令 2.codesign 签名及查看 3.xcode 工程编译 4.程序打包app---&g ...
- java之生成可重复执行的sql脚本
在实际项目开发过程中,sql脚本需要多次执行.而一般的DML和DDL语句一般只能执行一次,再次执行执行时就会报错(操作对应已存在/不存在),所以必须将sql脚本生成可重复执行的.本文共分为4部分:1. ...
- Go基础
Go编程基础 package 别名 当使用第三方包时,包名可能会非常接近或者相同,此时就可以使用别名来进行区别和调用 //当前程序的包名 package main //导入其他的包 import &q ...
- MarkDown---超强文本编辑器
What you see Is What you get ... --------------------------- Salmon 编辑器界面: ------------------------ ...
- C#异步编程(async and await)及异步方法同步调用
1.什么是异步? 异步操作通常用于执行完成时间可能较长的任务,如打开大文件.连接远程计算机或查询数据库=异步操作在主应用程序线程以外的线程中执行.应用程序调用方法异步执行某个操作时,应用程序可在异步方 ...
- python+selenium自动化软件测试(第16章):基础实战(3)
#coding:utf-8 from time import sleep from selenium import webdriver class cloudedge_register(object) ...
- Hadoop 如何退出安全模式
在name node 上运行如下命令 hadoop dfsadmin -safemode leave
- DOM+面向对象面试题
1.dom常见的节点类型---------------------------解彬1510-B 1.nodeType------节点类型,元素节点是1,文本节点是3. 2.firstChild---- ...
