程序员最近都爱上了这个网站  程序员们快来瞅瞅吧!  it98k网:it98k.com

本站消息

站长简介/公众号

  出租广告位,需要合作请联系站长


+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

Java-基础编程-多线程

发布于2021-01-01 16:48     阅读(882)     评论(0)     点赞(27)     收藏(1)


目录

一:程序,进程,线程

二.使用多线程的优点

四. Thread类的有关方法

五.线程的生命周期

六.线程的同步

七.线程的通信

八:经典的生产者消费者例题


一:程序,进程,线程

二.使用多线程的优点

三:线程的创建和启动

四. Thread类的有关方法

五.线程的生命周期

六.线程的同步

七.线程的通信

八:经典的生产者消费者例题

 线程通信的应用:经典例题:生产者/消费者问题
 生产者(Producer)将产品交给店员(Clerk),而消费者(Customer)从店员处取走产品,
 店员一次只能持有固定数量的产品(比如20),如果生产者试图生产更多的产品,店员会叫
 生产者停一下,如果店中有空位放产品了再通知生产者继续生产;如果店中没有产品了,店
 员会告诉消费者等一下,如果店中有产品了再通知消费者来取走产品
 分析:
 1)是否是多线程问题? 是,生产者线程,消费者线程
 2)是否有共享数据?     是, 店员(或者产品)
 3)如何解决线程的安全问题? 同步机制,有三种方法
 4)是否涉及线程的通信? 是

代码解决:

  1. class Clerk{
  2. private int productCount = 0;
  3. // 生产产品
  4. public synchronized void produceProduct() {
  5. if(productCount < 20) {
  6. productCount++;
  7. System.out.println(Thread.currentThread().getName() + ":开始生产第" + productCount);
  8. notify();
  9. }else {
  10. try {
  11. wait();
  12. } catch (InterruptedException e) {
  13. // TODO Auto-generated catch block
  14. e.printStackTrace();
  15. }
  16. }
  17. }
  18. // 消费产品
  19. public synchronized void consumeProduct() {
  20. if(productCount > 0) {
  21. System.out.println(Thread.currentThread().getName() + ":开始消费第"+ productCount);
  22. productCount--;
  23. notify();
  24. }else {
  25. try {
  26. wait();
  27. } catch (InterruptedException e) {
  28. // TODO Auto-generated catch block
  29. e.printStackTrace();
  30. }
  31. }
  32. }
  33. }
  34. class Producer extends Thread{
  35. private Clerk clerk;
  36. public Producer(Clerk clerk) {
  37. this.clerk = clerk;
  38. }
  39. @Override
  40. public void run() {
  41. System.out.println(getName()+":开始生产产品......");
  42. while(true) {
  43. try {
  44. Thread.sleep(10);
  45. } catch (InterruptedException e) {
  46. // TODO Auto-generated catch block
  47. e.printStackTrace();
  48. }
  49. clerk.produceProduct();
  50. }
  51. }
  52. }
  53. class Consumer extends Thread{
  54. private Clerk clerk;
  55. public Consumer(Clerk clerk) {
  56. this.clerk = clerk;
  57. }
  58. @Override
  59. public void run() {
  60. System.out.println(getName()+":开始消费产品......");
  61. while(true) {
  62. try {
  63. Thread.sleep(20);
  64. } catch (InterruptedException e) {
  65. // TODO Auto-generated catch block
  66. e.printStackTrace();
  67. }
  68. clerk.consumeProduct();
  69. }
  70. }
  71. }
  72. public class ProductTest {
  73. public static void main(String[] args) {
  74. Clerk clerk = new Clerk();
  75. Producer p1 = new Producer(clerk);
  76. p1.setName("生产者1");
  77. Consumer c1 = new Consumer(clerk);
  78. c1.setName("消费者1");
  79. Consumer c2 = new Consumer(clerk);
  80. c1.setName("消费者2");
  81. p1.start();
  82. c1.start();
  83. c2.start();
  84. }
  85. }

 

原文链接:https://blog.csdn.net/yezonghui/article/details/111832311



所属网站分类: 技术文章 > 博客

作者:java是世界上最好的语言

链接:http://www.javaheidong.com/blog/article/45956/efc52059f0b34c08f5d9/

来源:java黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

27 0
收藏该文
已收藏

评论内容:(最多支持255个字符)