Java基础系列-第一章 创建Thread的6种方式和线程常用方法

简介: 读完本章节,您将掌握如何创建线程和线程的常用方法。

前言

读完本章节,您将掌握如何创建线程和线程的常用方法。

一、创建线程

1. 通过Thread子类创建线程

   public class MyThread extends Thread {
        @Override
        public void run() {
            System.out.println("通过Thread子类创建线程");
        }
    }

    //通过Thread子类创建线程
    public void createThread1() {
        MyThread t = new MyThread();
        t.start();
    }

2. 使用runnable创建线程

2.1 通过函数式接口创建线程
    //使用runnable创建线程-函数式接口
    public void createThread2() {
        Thread t = new Thread(() -> System.out.println("使用runnable创建线程1"));
        t.start();
    }
2.2 通过内部匿名类创建线程
    //使用runnable创建线程-内部匿名类
    public void createThread3() {
        Thread t = new Thread(new Runnable() {
            @Override
            public void run() {
                System.out.println("使用runnable创建线程2");
            }
        });
        t.start();
    }
2.3 通过runnable子类创建线程
    public class MyRunnable implements Runnable {
        @Override
        public void run() {
            System.out.println("使用runnable创建线程3");
        }
    }

    //使用runnable创建线程-runnable子类
    public void createThread4() {
        MyRunnable runnable = new MyRunnable();
        Thread t = new Thread(runnable);
        t.start();
    }

3. 使用匿名内部类创建线程

    //使用匿名内部类创建线程
    public void createThread5() {
        Thread t = new Thread() {
            @Override
            public void run() {
                System.out.println("使用匿名内部类创建线程");
            }
        };
        t.start();
    }

4. 使用线程池创建线程

    @Resource
    private ThreadPoolExecutor threadPoolExecutor;

    @Bean
    public ThreadPoolExecutor executor() {
        int processors = Runtime.getRuntime().availableProcessors();
        return new ThreadPoolExecutor(
                Math.max(processors * 4, 6),
                Math.max(processors * 4, 8),
                0L,
                TimeUnit.MILLISECONDS,
                new LinkedBlockingDeque<>(100000),
                runnable -> {
                    Thread r = new Thread(runnable);
                    r.setName("thread-");
                    return r;
                }
        );
    }

    //使用线程池创建线程
    public void createThread6() {
        threadPoolExecutor.execute(() -> System.out.println("使用线程池创建线程"));
    }

二、线程常用静态方法

    //线程常用静态方法
    public void threadStaticMethod() throws InterruptedException {
        //将当前线程设为让步状态,表示当前线程愿意让出CPU资源使得其他线程执行。
        //将当前线程设为待运行就绪状态,再从线程池中取出可运行的线程执行后续逻辑,有可能取到刚放回去的当前线程。
        Thread.yield();
        //线程休眠(阻塞)100ms
        Thread.sleep(100L);
        //获取当前线程的信息
        Thread.currentThread();
        //返回当前线程的线程组中活动线程的数量。(返回的值只是一个估计值)
        Thread.activeCount();
        //获取线程中断标志位
        Thread.interrupted();
    }

三、线程实例常用方法

    //线程实例常用方法
    public void threadMethod() throws InterruptedException {
        Thread t = new Thread(() -> System.out.println("线程实例常用方法"));

        //当前线程等待t线程执行直到t执行完成
        //要让join方法正常生效,调用join方法的线程对象必须已经调用了start()方法并且未进入终止状态。
        //常见面试题:现在有T1、T2,你怎样保证T2在T1执行完之后执行,就可以在T2中调用t1.join()实现。
        t.join();

        //挂起当前线程和释放synchronized同步锁
        //wait()和notify()、notifyAll()都是java.lang.Object的方法。
        t.wait();

        //设为后台线程(守护线程)
        //java线程分为后台线程与前台线程,其中后台线程不会影响到进程的退出,而前台线程会影响进程的退出。
        //比如有线程t1与线程t2,当这两个线程为前台线程时,main方法执行完毕时,t1与t2不会立即退出,要等到线程执行完毕,整个进程才会退出,反之,当这两个线程为后台线程时,main方法执行完毕时,t1与t2线程被强制结束,整个进程也就结束了。
        t.setDaemon(true);

        //使用interrupt方法修改线程中断标志位为true,默认为false
        t.interrupt();

        //获取线程中断标志位
        //在线程run()方法里可以通过Thread.currentThread().isInterrupted()获取标志位。但是调用interrupt方法遇到线程run()方法里调用 wait/join/sleep 等方法而阻塞线程时会使sleep等方法抛出异常,并且中断标志位不会修改为true
        //可通过静态方法Thread.interrupted()代替,但注意:一个程序里Thread.interrupted()是共用的。
        t.isInterrupted();

        //以同步方式执行方法,不创建新线程
        t.run();

        //创建线程并执行run方法
        t.start();
    }

四、线程基本状态

NEW: 初始化状态。初始化线程对象,这时没有执行start方法,java内部的状态,与进程中的状态无关。
RUNNABLE: 就绪状态。分两种:RUNNABLE运行中,READY待运行。
BLOCKED: 阻塞状态。线程正在等待锁释放而引起的阻塞状态(synchronized加锁)。
WAITING: 等待状态。线程正在等待等待唤醒而引起的阻塞状态(wait方法使线程等待唤醒)。
TIMED_WAITING: 超时等待状态。在一段时间内处于阻塞状态,通常是使用sleep或者join(带参数)方法引起。
TERMINATED:终止状态。Thread对象还存在,但是关联的线程已经工作完成了,java内部的状态,与进程中的状态无关。

在这里插入图片描述

总结

读完本章节,您已经掌握如何创建线程和线程的常用方法。可以动手按照示例代码自己敲下进行测试和巩固。

目录
相关文章
|
11天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
51 4
|
22天前
|
Java API
Java 对象释放与 finalize 方法
关于 Java 对象释放的疑惑解答,以及 finalize 方法的相关知识。
43 17
|
16天前
|
Java 测试技术 Maven
Java一分钟之-PowerMock:静态方法与私有方法测试
通过本文的详细介绍,您可以使用PowerMock轻松地测试Java代码中的静态方法和私有方法。PowerMock通过扩展Mockito,提供了强大的功能,帮助开发者在复杂的测试场景中保持高效和准确的单元测试。希望本文对您的Java单元测试有所帮助。
32 2
|
24天前
|
Java 开发者
在Java多线程编程中,选择合适的线程创建方法至关重要
【10月更文挑战第20天】在Java多线程编程中,选择合适的线程创建方法至关重要。本文通过案例分析,探讨了继承Thread类和实现Runnable接口两种方法的优缺点及适用场景,帮助开发者做出明智的选择。
16 2
|
24天前
|
Java
在Java多线程编程中,实现Runnable接口通常优于继承Thread类
【10月更文挑战第20天】在Java多线程编程中,实现Runnable接口通常优于继承Thread类。原因包括:1) Java只支持单继承,实现接口不受此限制;2) Runnable接口便于代码复用和线程池管理;3) 分离任务与线程,提高灵活性。因此,实现Runnable接口是更佳选择。
30 2
|
24天前
|
Java
Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口
【10月更文挑战第20天】《JAVA多线程深度解析:线程的创建之路》介绍了Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口。文章详细讲解了每种方式的实现方法、优缺点及适用场景,帮助读者更好地理解和掌握多线程编程技术,为复杂任务的高效处理奠定基础。
28 2
|
17天前
|
Java Spring
JAVA获取重定向地址URL的两种方法
【10月更文挑战第17天】本文介绍了两种在Java中获取HTTP响应头中的Location字段的方法:一种是使用HttpURLConnection,另一种是使用Spring的RestTemplate。通过设置连接超时和禁用自动重定向,确保请求按预期执行。此外,还提供了一个自定义的`NoRedirectSimpleClientHttpRequestFactory`类,用于禁用RestTemplate的自动重定向功能。
|
6月前
|
存储 安全 Java
深入理解Java并发编程:线程安全与锁机制
【5月更文挑战第31天】在Java并发编程中,线程安全和锁机制是两个核心概念。本文将深入探讨这两个概念,包括它们的定义、实现方式以及在实际开发中的应用。通过对线程安全和锁机制的深入理解,可以帮助我们更好地解决并发编程中的问题,提高程序的性能和稳定性。
|
3月前
|
存储 安全 Java
解锁Java并发编程奥秘:深入剖析Synchronized关键字的同步机制与实现原理,让多线程安全如磐石般稳固!
【8月更文挑战第4天】Java并发编程中,Synchronized关键字是确保多线程环境下数据一致性与线程安全的基础机制。它可通过修饰实例方法、静态方法或代码块来控制对共享资源的独占访问。Synchronized基于Java对象头中的监视器锁实现,通过MonitorEnter/MonitorExit指令管理锁的获取与释放。示例展示了如何使用Synchronized修饰方法以实现线程间的同步,避免数据竞争。掌握其原理对编写高效安全的多线程程序极为关键。
64 1
|
4月前
|
安全 Java 开发者
Java并发编程中的线程安全问题及解决方案探讨
在Java编程中,特别是在并发编程领域,线程安全问题是开发过程中常见且关键的挑战。本文将深入探讨Java中的线程安全性,分析常见的线程安全问题,并介绍相应的解决方案,帮助开发者更好地理解和应对并发环境下的挑战。【7月更文挑战第3天】
92 0