线程的5大基本状态

本文详细介绍了Java中线程的几种操作,包括如何优雅地停止线程、使用线程休眠、线程礼让、join方法实现线程强制执行以及如何观测线程状态。同时,还探讨了线程的优先级设置和守护线程的概念。通过实例代码,深入理解Java线程的管理与控制。

线程停止

*
1 建议线程正常停止  利用次数,不建议死循环
2 建议使用标志位    设置一个标志位
3 不要使用stop或者destroy等过时或者JDK不建议使用的方法
 */
public class TestStop implements Runnable {
    // 1设置一个标识位
    private boolean flag = true;
    @Override
    public void run() {
        int i = 0;
        while (flag){
            System.out.println("线程正在运行"+i++);
        }
    }
//    停止方法
    public void stop(){
        this.flag = false;
    }

    public static void main(String[] args) {
        TestStop testStop = new TestStop();
         new Thread(testStop).start();

        for (int i = 0; i < 1000; i++) {
            System.out.println("main"+i);
            if (i == 900){
                testStop.stop();
                System.out.println("线程停止了");
            }
        }
    }
}

线程休眠

public class TestSleep implements Runnable{
    private int ticketNums = 10;
    @Override
    public void run() {
        while (true){
            if (ticketNums<=0){
                break;
            }
            //模拟延时
            try {
                Thread.sleep(200);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName()+"-->拿到了第"+ticketNums-- +"票");
        }

    }

    public static void main(String[] args) {
        TestSleep testSleep = new TestSleep();
        new Thread(testSleep,"小明").start();
        new Thread(testSleep,"老师").start();
        new Thread(testSleep,"黄牛").start();

    }
}

获取系统当前时间

public class TestSleep2 {
    public static void main(String[] args) {
        Date starTime = new Date(System.currentTimeMillis());//获取系统当前时间
        while (true){
            try {
                Thread.sleep(1000);
                System.out.println(new SimpleDateFormat("HH:mm:ss").format(starTime));
                starTime =  new Date(System.currentTimeMillis());//更新时间
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

线程礼让

//礼让不一定成功
public class TestYield {
    public static void main(String[] args) {
        MyYield myYield = new MyYield();
        new Thread(myYield,"A线程").start();
        new Thread(myYield,"B线程").start();
    }

}
class MyYield implements Runnable{
    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName()+"线程开始执行");
        Thread.yield();//礼让
        System.out.println(Thread.currentThread().getName()+"线程停止执行");
    }
}

线程强制执行 —join

//测试jion方法
public class TestJoin implements Runnable{
    @Override
    public void run() {
        for (int i = 0; i < 1000; i++) {
            System.out.println("线程vip"+i);
        }
    }

    public static void main(String[] args) throws InterruptedException {
        TestJoin testJoin = new TestJoin();
        Thread thread = new Thread(testJoin);
        thread.start();
        //主线程
        for (int i = 0; i < 500; i++) {
            if (i == 10){
                thread.join();
            }
            System.out.println("主线程"+i);
        }
    }
}

线程状态观测

//观测线程的状态
public class TestState {
    public static void main(String[] args) {
        Thread thread = new Thread(()->{
            for (int i = 0; i < 5; i++) {
                try {
                    Thread.sleep(100);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            System.out.println("/////");
        });
//观测状态
        Thread.State state = thread.getState();
        System.out.println(state);//NEW
//        观测启动后
        thread.start();
        state = thread.getState();
        System.out.println(state);//Run
        while (state != Thread.State.TERMINATED){//只要线程不终止就一直输出这个状态
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            state = thread.getState();//更新线程状态
            System.out.println(state);//输出状态
        }
    }

}

线程的优先级

//测试线程的优先级
public class TestPriority{
//    主线程的优先级
    public static void main(String[] args) {
        System.out.println(Thread.currentThread().getName()+"-->"+Thread.currentThread().getPriority());
        MyPriority myPriority = new MyPriority();
        Thread t1 = new Thread(myPriority);
        Thread t2 = new Thread(myPriority);
        Thread t3 = new Thread(myPriority);
        Thread t4 = new Thread(myPriority);
        Thread t5 = new Thread(myPriority);
//        先设置优先级,在启动
        t1.start();
        t2.setPriority(1);
        t2.start();

        t3.setPriority(4);
        t3.start();

        t4.setPriority(Thread.MAX_PRIORITY);
        t4.start();
        
        t5.setPriority(3);
        t5.start();
    }
}
class MyPriority implements Runnable{
    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName()+"-->"+Thread.currentThread().getPriority());
    }
}

线程守护 daemon

// 测试守护线程
// 上帝守护你
public class TestDaemon {
    public static void main(String[] args) {
        God god = new God();
        You you = new You();
        Thread thread = new Thread(god);
        thread.setDaemon(true);//默认是false表示用户线程,正常的都是用户线程
        thread.start();//守护线程启动
        new Thread(new You()).start();//用户线程启动

    }

}
//上帝
class God implements Runnable{
    @Override
    public void run() {
        while (true){
            System.out.println("上帝保佑着你");
        }
    }
}
//你
class You implements Runnable{
    @Override
    public void run() {
        for (int i = 0; i < 365000; i++) {
            System.out.println("你开心的活着");
        }
        System.out.println("-=====good bye world!");
    }
}

线程和进程是操作系统中的重要概念,它们具有不同的特点和状态。 进程是操作系统中的一个执行实体,它拥有独立的内存空间和资源。进程具有以下基本状态: 1. 创建(Created):进程正在被创建,但还没有分配到系统资源。 2. 就绪(Ready):进程已分配到了系统资源,但还没有开始执行。 3. 运行(Running):进程正在执行,占用 CPU 资源。 4. 阻塞(Blocked):进程由于某种原因暂停执行,等待某个事件的发生(比如等待输入/输出完成)。 5. 终止(Terminated):进程执行完毕或被终止,释放所占用的资源。 线程是进程中的一个执行单元,与同一进程中的其他线程共享进程的资源。线程具有以下基本状态: 1. 创建(Created):线程正在被创建,但还没有分配到系统资源。 2. 就绪(Ready):线程已分配到了系统资源,但还没有开始执行。 3. 运行(Running):线程正在执行,占用 CPU 资源。 4. 阻塞(Blocked):线程由于某种原因暂停执行,等待某个事件的发生(比如等待输入/输出完成)。 5. 终止(Terminated):线程执行完毕或被终止,释放所占用的资源。 需要注意的是,线程是在进程的上下文中执行的,进程的终止会导致其中所有线程的终止。同时,线程之间可以通过共享内存来进行通信,而进程之间通信的方式则更加复杂。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值