第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. 蓝桥杯算法训练_2的次幂表示+前缀表达式+Anagrams问题+出现次数最多的整数

    今天做了4个简单的题,题目虽然是简单,但是对于我这样的小白,还是有很多东西需要学习的. 2的次幂表示 上面就是题目,题目说的也很清晰了,接下来就是递归的实现: #include<iostream ...

  2. AngularJS优缺点、使用场景

    AngularJS 优缺点 优点: AngularJS模板功能强大丰富,自带了极其丰富的angular指令. AngularJS是完全可扩展的,与其他库的兼容效果很好,每一个功能可以修改或更换,以满足 ...

  3. python 在大文件里面删除某一行,比较有效率的方法

    用 python 处理一个文本时,想要删除其中中某一行,常规的思路是先把文件读入内存,在内存中修改后再写入源文件. 但如果要处理一个很大的文本,比如GB级别的文本时,这种方法不仅需要占用很大内存,而且 ...

  4. while补充,字符串和数字的内置方法

    一.while循环的补充 while True: name=input('please input your name: ') password=input('please input your pa ...

  5. LeetCode Algorithm

    LeetCode Algorithm 原文出处:[LeetCode] 算法参考:[陈皓 coolshell] 1. Two Sum 3. Longest Substring Without Repea ...

  6. StringBulider简单用法

    StringBuild的是个动态对象,可直接拼加上字符串:而string对象的步骤:先初始化对象并赋值了,而后在拼加字符串时,先要创建需要拼加的字符串,然后再拼加,所以这就是StirngBuild远比 ...

  7. 第一阶段项目(3body)

    <div class="H1">            <div class="top-nav">                < ...

  8. Redis和消息队列使用实战

    消息队列是在乐视这边非常普遍使用的技术.在我们部门内部,不同的项目使用的消息队列实现也不一样.下面是支付系统的流转图(部门兄弟画的,借用一下): 从图中可以看到,里面用到了kafka消息队列.作用是做 ...

  9. Linux学习总结(七)—— CentOS软件包管理:脚本安装

    脚本安装就是软件编写者写好一个shell脚本或者java脚本,你只需要输入一些简单的信息便可直接安装.这种安装方式方便简单,类似于Windows下软件的安装方式. 下面以webmin的安装为例讲解脚本 ...

  10. 【VMware Workstation】NAT映射虚拟机所在网络

    配置虚拟网络编辑器 配置网络映射关系