第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. HttpClient笔记与踩过的坑

    本来有个指纹采集功能做了个winFrom小程序 在本地测试都还能行,后来快上线的时候发现 客户用的阿里云数据库, 不对外公布 ,然后发现本地采集的数据没办法上传到数据库怎么办呢? 然后曲线救国,用we ...

  2. Spring思维导图(MVC篇)

    写在前面 生活就像海洋,只有意志坚强的人才能到达彼岸. 已经很久没有发文章了呀,想必大家都挂念我了,哈哈. 温故而知新,今天一起来复习一下spring mvc的内容吧. spring mvc简介与运行 ...

  3. MySQL Flush导致的等待问题

    --MySQL Flush导致的等待问题 -------------------------------2014/07/13 前言 在实际生产环境中有时会发现大量的sql语句处于waiting for ...

  4. C++ Socket学习记录 -3

    WinSocket套接字之间的数据传输 在客户端和服务端建立链接后,接着就是在套接字之间传输数据. 很简单的使用 recv 接收数据,用send发送数据,单但是出现一个问题,不管接收还是发送,数据都是 ...

  5. Qt将窗体变为顶层窗体

    //重载resizeEvent和moveEvent两个函数,以保证窗体大小和位置改变后能时刻记住其位置 QRect curGemRect = mpWindow->geometry(); //激活 ...

  6. C/C++ 知识点---LIB和DLL的区别与使用(网摘)

    LIB和DLL的区别与使用 原文出处:[远风工作室] 共有两种库:一种是LIB包含了函数所在的DLL文件和文件中函数位置的信息(入口),代码由运行时加载在进程空间中的DLL提供,称为动态链接库dyna ...

  7. 解析SS、SP、BP寄存器

    SS, SP, BP 三个寄存器 SS:存放栈的段地址: SP:堆栈寄存器SP(stack pointer)存放栈的偏移地址; BP: 基数指针寄存器BP(base pointer)是一个寄存器,它的 ...

  8. ubuntu 16.04下安装使用OpenCV2.4.13

    本来项目是在Windows下写的,结果对接的时候发现要在Linux下实现,没办法只能重新移植了.以前在ubuntu上使用过OpenCV,可惜系统已经重新安装过,只能重新来一遍了,索性就记录一下安装过程 ...

  9. java‘小秘密’系列(一)---String、StringBuffer、StringBuilder

    java'小秘密'系列(一)---String.StringBuffer.StringBuilder 前言:本系列的主题是平时容易疏忽的知识点,只有基础扎实,在编码的时候才能更注重规范和性能,在出现b ...

  10. HTML基础进阶

    [toc] HTML表单 form标签 <form> 标签代表一个表单,表单用于向服务器传输数据. 标签能够包含 <input> ,可以是文本字段,复选框,单选框或提交按钮等. ...