Thread类的常用结构

1.1 构造器

  • public Thread() :分配一个新的线程对象。

  • public Thread(String name) :分配一个指定名字的新的线程对象。

  • public Thread(Runnable target) :指定创建线程的目标对象,它实现了Runnable接口中的run方法

  • public Thread(Runnable target,String name) :分配一个带有指定目标新的线程对象并指定名字。

1.2 常用方法系列1

  • public void run() :此线程要执行的任务在此处定义代码。

  • public void start() :导致此线程开始执行; Java虚拟机调用此线程的run方法。

  • public String getName() :获取当前线程名称。

  • public void setName(String name):设置该线程名称。

  • public static Thread currentThread() :返回对当前正在执行的线程对象的引用。在Thread子类中就是this,通常用于主线程和Runnable实现类

  • public static void sleep(long millis) :使当前正在执行的线程以指定的毫秒数暂停(暂时停止执行)。

  • public static void yield():yield只是让当前线程暂停一下,让系统的线程调度器重新调度一次,希望优先级与当前线程相同或更高的其他线程能够获得执行机会,但是这个不能保证,完全有可能的情况是,当某个线程调用了yield方法暂停之后,线程调度器又将其调度出来重新执行。

1.3 常用方法系列2

  • public final boolean isAlive():测试线程是否处于活动状态。如果线程已经启动且尚未终止,则为活动状态。

  • void join() :等待该线程终止。

    void join(long millis) :等待该线程终止的时间最长为 millis 毫秒。如果millis时间到,将不再等待。

    void join(long millis, int nanos) :等待该线程终止的时间最长为 millis 毫秒 + nanos 纳秒。

  • public final void stop():已过时,不建议使用。强行结束一个线程的执行,直接进入死亡状态。run()即刻停止,可能会导致一些清理性的工作得不到完成,如文件,数据库等的关闭。同时,会立即释放该线程所持有的所有的锁,导致数据得不到同步的处理,出现数据不一致的问题。

  • void suspend() / void resume() : 这两个操作就好比播放器的暂停和恢复。二者必须成对出现,否则非常容易发生死锁。suspend()调用会导致线程暂停,但不会释放任何锁资源,导致其它线程都无法访问被它占用的锁,直到调用resume()。已过时,不建议使用。

1.4 常用方法系列3

每个线程都有一定的优先级,同优先级线程组成先进先出队列(先到先服务),使用分时调度策略。优先级高的线程采用抢占式策略,获得较多的执行机会。每个线程默认的优先级都与创建它的父线程具有相同的优先级。

  • Thread类的三个优先级常量:

    • MAX_PRIORITY(10):最高优先级

    • MIN _PRIORITY (1):最低优先级

    • NORM_PRIORITY (5):普通优先级,默认情况下main线程具有普通优先级。

  • public final int getPriority() :返回线程优先级

  • public final void setPriority(int newPriority) :改变线程的优先级,范围在[1,10]之间。

练习:获取main线程对象的名称和优先级。

声明一个匿名内部类继承Thread类,重写run方法,在run方法中获取线程名称和优先级。设置该线程优先级为最高优先级并启动该线程。

    public static void main(String[] args) {  
        Thread t = new Thread(){  
            public void run(){  
                System.out.println(getName() + "的优先级:" + getPriority());  
            }  
        };  
        t.setPriority(Thread.MAX_PRIORITY);  
        t.start();  
          
        System.out.println(Thread.currentThread().getName() +"的优先级:" +                                           Thread.currentThread().getPriority());  
    }

案例:

  • 声明一个匿名内部类继承Thread类,重写run方法,实现打印[1,100]之间的偶数,要求每隔1秒打印1个偶数。

  • 声明一个匿名内部类继承Thread类,重写run方法,实现打印[1,100]之间的奇数,

    • 当打印到5时,让奇数线程暂停一下,再继续。

    • 当打印到5时,让奇数线程停下来,让偶数线程执行完再打印。

package com.atguigu.api;  
​  
public class TestThreadStateChange {  
    public static void main(String[] args) {  
        Thread te = new Thread() {  
            @Override  
            public void run() {  
                for (int i = 2; i <= 100; i += 2) {  
                    System.out.println("偶数线程:" + i);  
                    try {  
                        Thread.sleep(1000);  
                    } catch (InterruptedException e) {  
                        e.printStackTrace();  
                    }  
                }  
            }  
        };  
        te.start();  
​  
        Thread to = new Thread() {  
            @Override  
            public void run() {  
                for (int i = 1; i <= 100; i += 2) {  
                    System.out.println("奇数线程:" + i);  
                    if (i == 5) {  
//                        Thread.yield();  
                        try {  
                            te.join();  
                        } catch (InterruptedException e) {  
                            e.printStackTrace();  
                        }  
                    }  
​  
                }  
            }  
        };  
        to.start();  
    }  
}

生产实践中的趣事:

Thread类的常用结构

1.5 守护线程(了解)

有一种线程,它是在后台运行的,它的任务是为其他线程提供服务的,这种线程被称为“守护线程”。JVM的垃圾回收线程就是典型的守护线程。

守护线程有个特点,就是如果所有非守护线程都死亡,那么守护线程自动死亡。形象理解:兔死狗烹鸟尽弓藏

调用setDaemon(true)方法可将指定线程设置为守护线程。必须在线程启动之前设置,否则会报IllegalThreadStateException异常。

调用isDaemon()可以判断线程是否是守护线程。

public class TestThread {  
    public static void main(String[] args) {  
        MyDaemon m = new MyDaemon();  
        m.setDaemon(true);  
        m.start();  
​  
        for (int i = 1; i <= 100; i++) {  
            System.out.println("main:" + i);  
        }  
    }  
}  
​  
class MyDaemon extends Thread {  
    public void run() {  
        while (true) {  
            System.out.println("我一直守护者你...");  
            try {  
                Thread.sleep(1);  
            } catch (InterruptedException e) {  
                e.printStackTrace();  
            }  
        }  
    }  
}
Java基础

创建线程的方式

2025-9-5 21:21:19

Java基础

线程安全问题及解决

2025-9-7 15:00:00

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
今日签到
有新私信 私信列表
搜索