zoukankan      html  css  js  c++  java
  • 多线程按序打印1-100

    1.两个线程交替打印

    package Mult_thread;
    
    public class turnPrint {
        private volatile int flag = 0;
        private volatile int count = 1;
        public static void main(String[] args) {
            turnPrint t = new turnPrint();
            t.getThread();
        }
        public void getThread(){
            Thread t1 = new Thread(new Thread1());
            Thread t2 = new Thread(new Thread2());
            t1.start();
            t2.start();
        }
        public class Thread1 implements Runnable{
            public void run(){
                while(count<=100){
                    if(flag==0){
                        System.out.println(count);
                        count++;
                        flag = 1;
                    }
                }
            }
        }
        public class Thread2 implements Runnable{
            public void run(){
                while(count<=100){
                    if(flag==1){
                        System.out.println(count);
                        count++;
                        flag = 0;
                    }
                }
            }
    
    
        }
    }
    public class Main {
        volatile int flag=0;
        public static void main(String[] args) throws InterruptedException {
            Main thread = new Main();
            thread.runThread();
        }
        public void runThread() throws InterruptedException{
            Thread t1=new Thread(new Thread1());
            Thread t2=new Thread(new Thread2());
            t1.start();
            t2.start();
        }
        public class Thread1 implements Runnable{
            public void run() {
                int i=1;
                while(i<=99){
                    if(flag==0)
                    {
                        System.out.println("t1="+i+"flag="+flag);
                        i+=2;
                        flag=1;
                    }
                }
            }
        }
        public class Thread2 implements Runnable{
    
            public void run() {
                int i=2;
                while(i<=100){
                    if(flag==1)
                    {
                        System.out.println("t2="+i+"flag="+flag);
                        i+=2;
                        flag=0;
                    }
                }
            }
        }
    }
    View Code

    2.三个线程交替打印

    import java.util.concurrent.atomic.AtomicInteger;
    
    
    public class Main2 {
        private volatile int i=1;
        private Thread thread1,thread2,thread3;
        private volatile int flag=0;
    
        public static void main(String[] args) throws InterruptedException {
            Main2 thread = new Main2();
            thread.runThread();
        }
        public void runThread() throws InterruptedException{
            thread1=new Thread(new Thread1());
            thread2=new Thread(new Thread2());
            thread3=new Thread(new Thread3());
            thread1.start();
            thread2.start();
            thread3.start();
        }
        public class Thread1 implements Runnable{
    
            public void run() {
                while(i<100){
                    if(flag==0) {
                        System.out.println("t1="+i);
                        i++;
                        flag=1;
                    }
                }
            }
    
        }
    
        public class Thread2 implements Runnable{
    
            public void run() {
    
                while(i<100){
                    if(flag==1){
                        System.out.println("t2="+i);
                        i++;
                        flag=2;
                    }
                }
            }
    
        }
    
        public class Thread3 implements Runnable{
    
            public void run() {
    
                while(i<100){
                    if(flag==2){
                        System.out.println("t3="+i);
                        i++;
                        flag=0;
                    }
                }
            }
    
        }
    }
    View Code
  • 相关阅读:
    一个不错的学习Hadoop和MapReduce的个人博客
    开源数据库sharding
    《控制论》导读 及 译者序 第二版序 读书笔记
    异常处理反模式
    主数据处理链碰到空数据节点不在继续执行的问题解决方案
    SAP 学习笔记 FI000 公司代码
    SAP概念之Client(集团),业务范围(business area),公司(company),公司代码(company code)
    零售行业主数据增量上载
    R/3数据源抽数到BWPSA中字段信息丢失
    BI CONTENT激活出现DUMP
  • 原文地址:https://www.cnblogs.com/jingpeng77/p/13531261.html
Copyright © 2011-2022 走看看