第11周作业-多线程


1.本周学习总结

2.书面作业

本次PTA作业题集多线程

1.互斥访问与同步访问

完成题集4-4(互斥访问)与4-5(同步访问)

1.1 除了使用synchronized修饰方法实现互斥同步访问,还有什么办法实现互斥同步访问(请出现相关代码)?

互斥访问还可采用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();
}
}

同步访问还可采用Condition方法:

public void setBalance(int balance) {
this.balance = balance;
} public synchronized void deposit(int money) {
setBalance(getBalance() + money);
Funds.signalAll();
} public synchronized void withdraw(int money) {
while (getBalance() <= 0) {
try {
Funds.await();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
setBalance(getBalance() - money);
Funds.signalAll();

1.2 同步代码块与同步方法有何区别?

  同步方法直接在方法上加synchronized实现加锁,同步代码块则在方法内部加锁。

1.3 实现互斥访问的原理是什么?请使用对象锁概念并结合相应的代码块进行说明。当程序执行synchronized同步代码块或者同步方法时,线程的状态是怎么变化的?

  当有某个任务访问该段代码时,给这段代码上锁,使其不能被其他任务访问,直到该代码解锁后才能被其他任务执行。

class Counter {
private static int value = 0;
public synchronized static void add() {
value++;
}
public synchronized static void subtract() {
value--;
}
public static int getValue() {
return value;
}
}

  当addsubtract没有使用synchronized修饰时,得到的运行结果是不确定的。当我们给他们上锁之后,假设线程1执行add方法,给getValue上锁,value值为1,然后解锁,线程2执行subtract方法,线程2就获得了锁,运行后value为0,解锁。所以最后的结果就为0。

1.4 Java多线程中使用什么关键字实现线程之间的通信,进而实现线程的协同工作?为什么同步访问一般都要放到synchronized方法或者代码块中?

  使用wait()、notify()来实现线程之间的协作。同步访问一般都要放到synchronized方法或者代码块中是为了避免出现多个线程访问同一个代码块时会导致的运行结果出错的情况。

2.交替执行

实验总结(不管有没有做出来)


  这应该是印象中写过的最长的函数题了,也是自己第一次遇到运行超时的情况。这题要注意的就是,所有的方法都要使用synchronized来修饰来实现互斥。当一个线程结束后要改变预设的flag值来指示当前任务结束,然后在唤醒另一个任务。

3.互斥访问

3.1 修改TestUnSynchronizedThread.java源代码使其可以同步访问。(关键代码截图,需出现学号)




  对addIdsubtractId方法使用synchronized修饰。

3.2 进一步使用执行器改进相应代码(关键代码截图,需出现学号)

参考资料:Java多线程之Executor、ExecutorService、Executors、Callable、Future与FutureTask


使用ExecutorService、Executor

使用Callable:

4.线程间的合作:生产者消费者问题

4.1 运行MyProducerConsumerTest.java。正常运行结果应该是仓库还剩0个货物。多运行几次,观察结果,并回答:结果正常吗?哪里不正常?为什么?


  不正常。有时候会出现“仓库还剩10个货物”的情况,原因是生产者与消费者的存取速度不相同。

4.2 使用synchronized, wait, notify解决该问题(关键代码截图,需出现学号)

4.3 选做:使用Lock与Condition对象解决该问题。

	public synchronized void add(String t) {// 201521123107
poolLock.lock();
try {
while (repo.size() == capacity) {
try {
condition.await();
} catch (InterruptedException e) {
// TODO: handle exception
e.printStackTrace();
}
}
repo.add(t);
condition.signalAll();
} finally {
poolLock.unlock();
}
} public synchronized void remove() {
poolLock.lock();
try {
while (repo.size() == 0) {
try {
condition.await();
} catch (InterruptedException e) {
// TODO: handle exception
e.printStackTrace();
}
}
repo.remove(0);
condition.signalAll();
} finally {
poolLock.unlock();
}
}

5.查询资料回答:什么是线程安全?(用自己的话与代码总结,写自己看的懂的作业)

  线程安全是当我们让多个线程执行同一段代码时,程序的运行结果不会出错。线程安全可以依靠线程同步来实现。

	public synchronized void withdraw(int money) {
while (getBalance() <= 0) {
try {
Funds.await();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
setBalance(getBalance() - money);
Funds.signalAll();

  这是作业中的取钱的关键代码,在多线程情况下,如只有一个存钱的线程,但是有多个取钱的线程,很可能会抛出异常。我们可以使用synchronized关键字,就可以确保一次只能有一个线程在取钱。

6.选做:实验总结

6.1 4-8(CountDownLatch)实验总结


  CountDownLatch是上课没有讲过的东西,每次调用 countDown() 方法, CountDownLatch 对象内部计数器减一。当内部计数器达到0时, CountDownLatch 对象唤醒全部使用 await() 方法睡眠的线程们。至于固定线程数线程池,我们就使用Executors.newFixedThreadPool(poolSize)即可。

  

6.2 4-9(集合同步问题)实验总结

  这个集合同步问题,上课也没有讲过,在课件里也找不着,就上网先学习一下,用法就是使用Collections工具类中的同步包装方法,将线程不安全ArrayList进行包装。

3. 码云上代码提交记录及PTA实验总结

题目集:多线程(4-4到4-10)

3.1. 码云代码提交记录


**在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图

3.2 截图多线程PTA提交列表**

201521123107 《Java程序设计》第11周学习总结的更多相关文章

  1. 201521123045 <java程序设计>第11周学习总结

    201521123045 <java程序设计>第11周学习总结 1. 本周学习总结 2. 书面作业 2. 书面作业 Q1.1.互斥访问与同步访问完成题集4-4(互斥访问)与4-5(同步访问 ...

  2. 201521123027 <java程序设计>第11周学习总结

    1.本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 2.书面作业 1.互斥访问与同步访问 完成题集4-4(互斥访问)与4-5(同步访问) 1.1 除了使用synchro ...

  3. 2018面向对象程序设计(Java)第11周学习指导及要求

    2018面向对象程序设计(Java)第11周学习指导及要求 (2018.11.8-2018.11.11)   学习目标 (1) 掌握Vetor.Stack.Hashtable三个类的用途及常用API: ...

  4. 面向对象程序设计(JAVA) 第11周学习指导及要求

    2019面向对象程序设计(Java)第11周学习指导及要求 (2019.11.8-2018.11.11)   学习目标 理解泛型概念: 掌握泛型类的定义与使用: 掌握泛型方法的声明与使用: 掌握泛型接 ...

  5. 20145236 《Java程序设计》第九周学习总结

    20145236 <Java程序设计>第九周学习总结 教材学习内容总结 第十六章 整合数据库 JDBC简介 1.JDBC是java联机数据库的标准规范.它定义了一组标准类与接口,标准API ...

  6. 2018-2019 2 20175230《Java程序设计》第九周学习总结

    <Java程序设计>第九周学习总结 主要内容 MySQL数据库管理系统 1.下载 2.安装 启动MySQL数据库服务器 1.启动 2.root用户 MySQL客户端管理工具 建立连接 建立 ...

  7. 20175209 《Java程序设计》第九周学习总结

    20175209 <Java程序设计>第九周学习总结 一.教材知识点总结 有关数据库下载中存在可能出现的问题已经在博客<数据库安装和使用过程中出现的一些问题>给出了相应的解决办 ...

  8. 20175208 《Java程序设计》第九周学习总结

    20175208 2018-2019-2 <Java程序设计>第九周学习总结 一.教材学习内容总结: 第11章 JDBC与MySQL数据库 MySQL数据库管理系统 MySQL数据库管理系 ...

  9. 20175202 《Java程序设计》第九周学习总结

    20175202 2018-2019-2 <Java程序设计>第九周学习总结 教材知识点总结 第11章 JDBC与MySQL数据库 MySQL数据库管理系统 MySQL数据库管理系统,简称 ...

  10. 20175227张雪莹 2018-2019-2 《Java程序设计》第九周学习总结

    20175227张雪莹 2018-2019-2 <Java程序设计>第九周学习总结 教材学习内容总结 第十一章 JDBC数据库操作 MySQL数据库管理系统 下载安装MySQL 若下载的是 ...

随机推荐

  1. 【待整理】MySQL alter table modify vs alter table add产生state不一样

    MySQL:5.6.35 OS:redhat5.8 今天更新数据库某些表字段,有如下两SQL: ①alter table xx modify xxxx;(表大概是77w) ②alter table s ...

  2. private static final long serialVersionUID = 1L;详解

    public class User implements Serializable { /** * serialVersionUID */ private static final long seri ...

  3. python_求相邻数

    什么是相邻数? 比如5,相邻数为4和6,和5相差1的数,连续相差为1的一组数 需求: 遍历inputList 所有数字,取出所有数字,判断是否有相邻数, 不相邻数字 和 相邻数字 都以 “数组”形式 ...

  4. javascript-数组的常用方法

    不知大家是否有过跟我类似的经历,就是切图仔刚开始做切图页面的时候,经常调用一些别人写的jquery插件,例如音乐播放器这种需要切换多首音乐的插件.调用的时候就必须有一个音乐队列,而这个队列就是一个数组 ...

  5. KeepAlived+Nginx实现高可用负载

    一.环境及安装版本: centos6.5.Nginx1.4.7.keepalived1.3.2 虚拟IP 真是IP Nginx端口 主从分配 10.0.90.215 10.0.90.217 80 MA ...

  6. SQL语句:Group By总结

    1. Group By 语句简介: Group By语句从英文的字面意义上理解就是"根据(by)一定的规则进行分组(Group)".它的作用是通过一定的规则将一个数据集划分成若干个 ...

  7. ORACLE概要文件

    oracle系统为了合理分配和使用系统的资源提出了概要文件的概念.所谓概要文件,就是一份描述如何使用系统的资源(主要是CPU资源)的配置文件.将概要文件赋予某个数据库用户,在用户连接并访问数据库服务器 ...

  8. 使用build_opener 自定义 opener

    使用build_opener 自定义 opener,这种方法的好处是可以方便的拓展功能. import urllib.request import http.cookiejar def makeMyO ...

  9. 【渗透课程】第二篇下-HTTP协议的请求与响应深度剖析

    [渗透课程]第二篇下-HTTP协议的请求与响应深度剖析 HTTP1.1目前支持以下7种请求方法: 常见的MIME类型如下: 第一个数字有五种可能的取值: 目录 什么是请求方法?什么是请求头? HTTP ...

  10. Java并发编程-阻塞队列

    Java concurrent 包中BlockingQueue接口有ArrayBlockingqueue.LinkedBlockingQueue.PriorityBlockingQueue.Synch ...