Статус потока, приоритет и поток демона | Многопоточность Java (4)

Java задняя часть
Статус потока, приоритет и поток демона | Многопоточность Java (4)

Это 28-й день моего участия в Gengwen Challenge.Подробности о мероприятии:Обновить вызов


Статьи по Теме

Резюме многопоточности Java:Многопоточность Java


Во-первых, состояние потока

  • newНить, которая не была начата, в этом состоянии

  • RunnableПоток, выполняющийся на виртуальной машине Java, находится в этом состоянии

  • BlockedВ этом состоянии находится поток, заблокированный в ожидании блокировки монитора.

  • WaitingПоток, ожидающий, пока другой поток выполнит определенное действие, находится в этом состоянии.

  • Timed WaitingПоток, ожидающий выполнения действия другим потоком в течение указанного времени ожидания, находится в этом состоянии.

  • TerminatedВ этом состоянии находится завершенный поток.

  • Кодовый регистр

/**
 * 线程的状态
 */
public class TestThreadStatus{

    public static void main(String[] args) throws InterruptedException {
        //我们用lamda表达式来启动一个线程
        Thread th = new Thread(()->{
            for (int i = 0; i <5 ; i++) {
                try {
                    Thread.sleep(100);

                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            System.out.println("////////////////");
        });

        Thread.State state = th.getState();
        System.out.println("创建时线程的状态+"+state);//线程的状态

        th.start();//启动线程
        state = th.getState();
        System.out.println("启动时线程的状态+"+state);

        //只要线程不终止就输入线程状态
        while (state != Thread.State.TERMINATED){
            Thread.sleep(100);
            state = th.getState();
            System.out.println("new+"+state);
        }



    }

}

  • Результат выполнения следующий:

在这里插入图片描述

Во-вторых, приоритет потока

  • Java предоставляет планировщик потоков для мониторинга всех потоков в программе, которые переходят в состояние готовности после запуска.Планировщик потоков решает, какой поток следует запланировать для выполнения в соответствии с приоритетом.

  • Приоритет потока представлен числом от 1 до 10.

  • Изменить или получить приоритет с помощью

    • getPriority().setPriority(int xxx)
  • Случай кода:

/**
 * 线程优先级,不一定成功
 */
public class TestThreadPriority {
    public static void main(String[] args) {
        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);
        Thread t6 = new Thread(myPriority);
        //先设置线程优先级
        t1.setPriority(1);
        t1.start();
        t2.setPriority(3);
        t2.start();
        t3.setPriority(6);
        t3.start();
        t4.setPriority(Thread.MAX_PRIORITY);//  优先级=10
        t4.start();
        t5.setPriority(Thread.MIN_PRIORITY);// 优先级=1
        t6.setPriority(9);
        t6.start();

        System.out.println("main");
    }
}

class MyPriority implements Runnable{

    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName()+"---线程被执行了!---"+Thread.currentThread().getPriority());
    }
}
  • Результат выполнения следующий:

在这里插入图片描述

3. Оберегающая нить

  • Потоки делятся на пользовательские потоки и потоки демона.

  • Виртуальная машина должна убедиться, что пользовательский поток завершил выполнение.

  • Виртуальной машине не нужно ждать завершения выполнения потока демона.

    • Например, записывать журналы операций в фоновом режиме, контролировать память и ждать сборки мусора. . .
  • Кодовый регистр

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);//默认为flase 为用户线程,  true为守护线程
        thread.start();
        new Thread(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 <36500 ; i++) {
            System.out.println("开心着活着每一天------");
        }
        System.out.println("----goodbye!Beautiful World!!!------");

    }
}
  • Результат выполнения следующий:

在这里插入图片描述


Впереди долгий путь, и я обязательно буду его искать вдоль и поперёк~

Если вы думаете, что я блогеры хорошо пишу! Писать нелегко, пожалуйста, ставьте лайки, подписывайтесь и комментируйте, чтобы поощрять блоггеров ~ хахах