实际应用java多线程 java 多线程应用

2023-06-09


情景1


如果有Thread11、Thread2、ThreaD3、四条线程各自统计CThread4。、D、E、四盘大小,全过程统计完毕,交给Thread5进程进行汇总,该如何实现?


第一,通过java.util.concurrent.在Executors中创建一个线程池,并使用这个线程池来启动这个过程。启动所有要启动的过程后,执行线程池的shutdown()方法,即在所有过程完成后关闭线程池。然后通过isTerminated()线程池的方法来判断线程池是否已关闭。成功关闭线程池,意味着整个过程已经完成。








import java.util.concurrent.ExecutorService;  
import java.util.concurrent.Executors;  

public class Test {  
    public static void main(String args[]) throws InterruptedException {  
        ExecutorService exe = Executors.newFixedThreadPool(50);  
        for (int i = 1; i <= 5; i  ) {  
            exe.execute(new SubThread(i));  
        }  
        exe.shutdown();  
        while (true) {  
            if (exe.isTerminated()) {  
                System.out.println(“结束了!");  
                break;  
            }  
            Thread.sleep(200);  
        }  
    }  
}



View Code




2)使用T.join,让主线程等待这些工作线程结束。








public class 011JoinTester implements Runnable {

    private String name;

    public 011JoinTester(String name) {
        this.name = name;
    }

    public void run() {
        System.out.printf("%s begins: %s\n", name, new Date());
        try {
            TimeUnit.SECONDS.sleep(4);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.printf("%s has finished: %s\n", name, new Date());
    }

    public static void main(String[] args) {
        while (true){
            Thread thread1 = new Thread(new “JoinTester01”One"));
            Thread thread2 = new Thread(new “JoinTester01”Two"));
            thread1.start();
            thread2.start();
            try {
                thread1.join();
                thread2.join();
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            System.out.println("Main thread is finished");
        }

    }
}



View Code




情景2


实现经典消费模式








1 package com.example.demo.consumer;
 2 
 3 import java.util.LinkedList;
 4 
 5 /**
 6  *  生产者和消费者之间的问题
 7  *  wait、notify/notifyAll() 实现
 8  */
 9 public class Storage1 implements AbstractStorage {
10     //仓库最大容量
11     private static final int _1MB = 128;
12     private final int MAX_SIZE = 100;
13     //仓库存储载体
14     private LinkedList list = new LinkedList();
15     //private Object object = new Object();
16     //进行生产
17     public void produce(int num){
18         //同步
19         synchronized (list){
20             //仓库剩余容量不足以储存即将生产的总产量,暂停生产
21             while(list.size() num > MAX_SIZE){
22                 System.out.println("""要生产的产品数量":"   num   "\t【库存量】:"
23                           list.size()   "\t暂时无法完成生产任务!");
24 
25                 try {
26                     //不符合条件,生产堵塞
27                     list.wait();
28                 } catch (InterruptedException e) {
29                     e.printStackTrace();
30                 }
31             }
32 
33             for(int i=0;i list.size()){
50                 System.out.println(“要消费的产品数量”:"   num   "\t【库存量】:"
51                           list.size()   "\t暂时无法完成消费任务!");
52 
53                 try {
54                     list.wait();
55                 } catch (InterruptedException e) {
56                     e.printStackTrace();
57                 }
58             }
59                 //满足消费条件,开始消费
60                 for(int i=0;i



Storage1










public class Test{
    public static void main(String[] args) {
        // 仓库目标
        AbstractStorage abstractStorage = new ()Storage1();

        // 生产者目标
        Producer p1 = new Producer(abstractStorage);
        Producer p2 = new Producer(abstractStorage);
        Producer p3 = new Producer(abstractStorage);
        Producer p4 = new Producer(abstractStorage);
        Producer p5 = new Producer(abstractStorage);
        Producer p6 = new Producer(abstractStorage);
        Producer p7 = new Producer(abstractStorage);

        // 顾客目标
        Consumer c1 = new Consumer(abstractStorage);
        Consumer c2 = new Consumer(abstractStorage);
        Consumer c3 = new Consumer(abstractStorage);

        // 设定生产者产品制造数量。
        p1.setNum(10);
        p2.setNum(10);
        p3.setNum(10);
        p4.setNum(10);
        p5.setNum(10);
        p6.setNum(10);
        p7.setNum(80);

        // 设定客户消费商品的数量
        c1.setNum(50);
        c2.setNum(20);
        c3.setNum(30);

        // 进程开始实施
        c1.start();
//        try {
//            Thread.sleep(1000);
//        } catch (InterruptedException e) {
//            e.printStackTrace();
//        }
//        abstractStorage.test();
        c2.start();
        c3.start();

        p1.start();
        p2.start();
        p3.start();
        p4.start();
        p5.start();
        p6.start();
        p7.start();
    }
}



main function




to be continued





本文为转载内容,我们尊重原作者对本文的作权。如有内容错误或侵权问题,欢迎原作者联系我们更正或删除内容。

本文仅代表作者观点,版权归原创者所有,如需转载请在文中注明来源及作者名字。

免责声明:本文系转载编辑文章,仅作分享之用。如分享内容、图片侵犯到您的版权或非授权发布,请及时与我们联系进行审核处理或删除,您可以发送材料至邮箱:service@tojoy.com