201521123026《JAVA程序设计》第11周学习总结
1. 本章学习总结
1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容。
1.多线程同步:限制某个资源在同一时刻只能被一个线程访问。。
2.同步代码块:`synchronized(lock){操作共享资源代码块}`,其锁是自己定义的任意类型的对象。
3.同步方法:`synchronized返回值类型 方法名(){}`,其锁是当前调用该方法的对象即this所指向的对象。
4.死锁问题:两个线程在运行时都在等待对方的锁,造成程序的停滞。
5.多线程通信:控制多个线程按照一定的顺序轮流执行。Object类中提供了wait()、notify()、notifyAll()方法用于解决线程间的通信问题。
2. 书面作业
1.互斥访问与同步访问
完成题集4-4(互斥访问)与4-5(同步访问)
1.1 除了使用synchronized修饰方法实现互斥同步访问,还有什么办法实现互斥同步访问(请出现相关代码)?
答:
Condition对象,ReentrantLock对象,lock对象,unlock方法可以实现互斥同步访问。
class Account {
private int balance;
private Lock poolLock = new ReentrantLock();
public Account(int balance) {
super();
this.balance = balance;
}
public int getBalance() {
return balance;
}
public void setBalance(int balance) {
this.balance = balance;
}
public void deposit(int money) {
poolLock.lock();
setBalance(getBalance() + money);
poolLock.unlock();
}
public void withdraw(int money) {
poolLock.lock();
setBalance(getBalance() - money);
poolLock.unlock();
}
}
1.2 同步代码块与同步方法有何区别?、
答:
同步步代码块:synchronized(lock){操作共享资源代码块},其锁是自己定义的任意类型的对象。
同步方法:synchronized返回值类型 方法名(){},其锁是当前调用该方法的对象即this所指向的对象。
此外,同步方法作用于整个方法,同步代码块作用于整个代码块。
1.3 实现互斥访问的原理是什么?请使用对象锁概念并结合相应的代码块进行说明。当程序执行synchronized同步代码块或者同步方法时,线程的状态是怎么变化的?
答:
实现互斥访问的原理:一个获得了所访问资源的对象锁的线程在访问资源的时候,其他访问该资源的进程会发生阻塞,进而必须进行等待,直到当前线程访问完毕后,其对象锁被释放,其他线程才有机会访问该资源。(即限制某个资源在同一时间只能被一个资源访问)
互斥:进程间相互排斥的使用临界资源的现象,就叫互斥。
对象锁(synchronized修饰方法或代码块):当一个对象中有synchronized method或synchronized block的时候调用此对象的同步方法或进入其同步区域时,就必须先获得对象锁。如果此对象的对象锁已被其他调用者占用,则需要等待此锁被释放。
结合代码分析:
class Counter {
private static int id = 0;
public synchronized static void addId() {
id++;
}
public synchronized static void subtractId() {
id--;
}
public static int getId() {
return id;
}
}
以作业TestUnSynchronizedThread026中的代码为例,设置两个进程t1和t2,线程t1调用add方法,线程B调用sub方法,id的初始值为0。
操作步骤如下:
1.线程t1获得id的锁,读取id的值,为0;(线程t2等待)
2.线程t1在取到的值上加1,结果为1;
3.线程t1将结果存回id,id=1,id的锁被解锁资源释放
4.线程t2获得id上的锁,读取id的值,为1
5.线程t2在取到的值上减1,结果为0
6.线程t2将结果存回id,id现在为0,id的锁被解锁资源释放
1.4 Java多线程中使用什么关键字实现线程之间的通信,进而实现线程的协同工作?为什么同步访问一般都要放到synchronized方法或者代码块中?
答:
(1)Java中可以用wait () 和notify()/notifyAll()方法来实现线程之间的通信,进而实现线程的协同工作。
(2)同步访问放到synchronized方法或者代码块中可以防止多个线程访问同一资源所引起的线程安全问题。
2.交替执行
实验总结(不管有没有做出来)
答:
先是建立Repo类;Worker1和Worker2类继承Runnable接口。因为Worker1和Worker2类可以从Repo对象中获取任务。所以Repo类中有run1()和run2()方法分别用synchronized关键字修饰。run1()循环条件是getSize()>0,当flag!=true时,输出并使flag的值为true。当flag为true时,work1线程等待换work2执行。run2()循环条件也是getSize()>0,当flag!=false时,输出并使flag的值为false。当flag为falsee时,work2线程等待换work1执行。通过这两个函数达到交替执行的结果。
3.互斥访问
3.1 修改TestUnSynchronizedThread.java源代码使其可以同步访问。(关键代码截图,需出现学号)
答:
3.2 进一步使用执行器改进相应代码(关键代码截图,需出现学号)
参考资料:Java多线程之Executor、ExecutorService、Executors、Callable、Future与FutureTask
答:
invokeAll方法有两种格式:
(1)invokeAll(tasks) 批量提交不限时任务。
(2)invokeAll(tasks, timeout, unit) 批量提交限时任务。
4.线程间的合作:生产者消费者问题
4.1 运行MyProducerConsumerTest.java。正常运行结果应该是仓库还剩0个货物。多运行几次,观察结果,并回答:结果正常吗?哪里不正常?为什么?
答:
运行多次代码发现每次代码运行结果并不一定相同,有时候结果还会为仓库还剩10个货物。很显然,结果是不正常的。因为生产者和消费者两个进程的存取速度不同,出现以下问题:(1)生产者比消费者快时,消费者来不及取数据; (2)消费者比生产者快时,消费者可能取不到数据。
4.2 使用synchronized, wait, notify解决该问题(关键代码截图,需出现学号)
答:
5.查询资料回答:什么是线程安全?(用自己的话与代码总结,写自己看的懂的作业)
答:
线程安全问题就是由于多个线程同时处理共享资源所导致的。如果一段代码每次多线程运行结果和单线程运行的结果是一样的,而且其他的变量的值也和预期的是一样的,就是线程安全的。举个简单的例子,就像简单的多线程售票系统,当票的余额只剩一张的时候,如果没有处理线程安全问题,就可能出现多个售票窗口同时将这一个票进行售出的情况,从而使票数出现负数。限制了多个售票窗口同时对一张票资源进行售出的情况,可以有效解决票数余额为负数的情况。
3.本周码云代码Commit历史截图
答:
4.截图多线程PTA提交列表
答:
201521123026《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 若下载的是 ...
随机推荐
- 防火墙和iptables
本文目录: 6.1 为什么需要防火墙 6.2 数据传输流程 6.2.1 网络数据传输过程 6.2.2 本机数据路由决策 6.3 TCP三次握手.四次挥手以及syn攻击 6.3.1 三次握手建立tcp连 ...
- MarkdownPad2之安装破解
MarkdownPad2之安装破解 一.下载破解版 1.地址链接:http://pan.baidu.com/s/1i5JzG13 密码: 4jgw 2.按步骤安装后,进行汉化:[Tool]--> ...
- tomcat运行时JVM参数调整
进入tomcat/bin目录 catalina.bat 中加入set JAVA_OPTS=-Xms210m -Xmx256m -Xmn70m -XX:PermSize=150m -XX:MaxPerm ...
- Java 开发环境配置(Windows篇)
window系统安装java 下载JDK 首先我们需要下载java开发工具包JDK,下载地址:http://www.oracle.com/technetwork/java/javase/downloa ...
- 34、锁问题与线程queue
上一篇随笔我们学了全局解释器锁,前面也学了互斥锁,今天学习一些与锁相关的点,例如递归锁,信号量,Event,还会学习我们已经很熟悉的队列,不过这次的队列是作为一个模块出现的. 一.同步锁 1.join ...
- #define和typedef在windows上的应用
typedef的应用 typedef是在计算机编程语言中用来为复杂的声明定义简单的别名. 下面的代码定义了一些常见类型的别名 typedef int INT; typedef unsigned int ...
- Java入门(7)——循环和debug 调试
循环: while 循环: 格式: int i = 0; ① //初始化条件 while(i < 10) { ② //判断条件 System.out.println(i); ④ //循环 ...
- mysql查看表结构2种方式对比
1.desc t_bookType; 2.show create table t_bookType; 相信大部分人还是喜欢第一种查看表结构方式.
- 扩展Python模块系列(五)----异常和错误处理
在上一节中,讨论了在用C语言扩展Python模块时,应该如何处理无处不在的引用计数问题.重点关注的是在实现一个C Python的函数时,对于一个PyObject对象,何时调用Py_INCREF和Py_ ...
- 学习js的点点滴滴记录
从安装完node.js后(里面自带了npm), 每个模块下都有个 package.json文件,在这个目录下打开cmd后 输入npm install 就是按照package.json里面的内容进行安装 ...