Java入门—多线程

简介: 线程是比进程还要小的运行单位,一个进程包含多个线程。什么是多线程线程的创建两种方式:创建一个Thread类,或者一个Thread子类的对象创建一个实现Runnable接口的类的对象Thread类:Thread是一个线程类,位于java.

线程是比进程还要小的运行单位,一个进程包含多个线程。

什么是多线程

线程的创建

两种方式:

  1. 创建一个Thread类,或者一个Thread子类的对象
  2. 创建一个实现Runnable接口的类的对象
Thread类:
  • Thread是一个线程类,位于java.lang包下


    img_09e5cbe5a84a2e25efbfcb1f06a82aff.png
    image.png
  • Thread类的常用方法


    img_dd260b2f3372291f3eab5e8646835b58.png
    image.png
Runnable接口
  • 只有一个方法run()
  • Runnable是java中用以实现线程的接口
  • 任何实现线程功能的类都必须实现该接口

继承Thread类的方式创建线程类,重写run方法:

package com.imooc.thread;

class MyThread extends Thread{
    public void run(){
        System.out.println(getName()+"该线程正在执行!");
    }
}

public class ThreadTest{
    public static void main(String[] args){
        System.out.println("主线程1");
        MyThread mt = new MyThread();
        mt.start();

        System.out.println("主线程2");
    }
}

Runnable创建线程:
为什么要实现Runnable接口?

因为:

  1. Java不支持多继承
  2. 当你不打算重写Thread类的其他方法
package com.imooc.thread;

class PrintRunnable implements Runnable{
    @Override
    public void run() {
        int i = 1;
        while (i<=5){
            System.out.println(Thread.currentThread().getName()+"正在运行");
            i++;
        }
    }
}

public class ThreadTest{
    public static void main(String[] args){
        PrintRunnable pr = new PrintRunnable();
        Thread t1 = new Thread(pr);
        t1.start();

        Thread t2 = new Thread(pr);
        t2.start();
    }
}

线程的状态和生命周期

线程的状态
  • 新建
  • 可运行
  • 正在运行
  • 阻塞
  • 终止
线程的生命周期
img_6387bcbb8cfcabe214c890710d201a6f.png
image.png
sleep方法:在指定的毫秒数内,让线程休眠。(暂停执行)
public static void sleep(long millis)

参数单位:毫秒
示例:

class MyThread implements Runnable{

    @Override
    public void run() {
        for(int i = 0; i<10;i++){
            System.out.println(Thread.currentThread().getName()+i);
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }

        }
    }
}
public class Test {
    public static void main(String[] args){
        MyThread m = new MyThread();
        Thread t = new Thread(m);
        t.start();
    }
}

调用sleep时需要捕获异常。

join()方法:优先执行线程。(抢占资源)
public final void join()

join方法的参数为毫秒,代表:超过此时间交出资源使用权。

示例:

class MyThread implements Runnable{

    @Override
    public void run() {
        for(int i = 0; i<10;i++){
            System.out.println(Thread.currentThread().getName()+i);
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}
public class Test {
    public static void main(String[] args){
        MyThread m = new MyThread();
        Thread t = new Thread(m);
        t.start();
        try {
            t.join(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        for(int j = 0; j<10;j++){
            System.out.println("主线程");
        }

    }
}

线程的调度

线程优先级
  • Java为线程类提供了10个优先级
  • 优先级可以用整数1-10表示,超出范围会抛出异常
  • 主线程默认优先级为5
  • 优先级常量
    • MAX_PRIORITY : 最高优先级(10)
    • MIN_PRIORITY : 最低优先级(1)
    • NORM_PRIORITY :默认优先级(5)
img_e36e79b09d6f519564ab414b71461278.png
image.png

测试代码:

class MyThread implements Runnable{
    private String name;
    public  MyThread(String name){
        this.name = name;
    }
    @Override
    public void run() {
        for(int i = 0; i<10;i++){
            System.out.println(Thread.currentThread().getName()+i+name);
        }
    }
}
public class Test {
    public static void main(String[] args){
        int i = Thread.currentThread().getPriority();

        MyThread m = new MyThread("Allen");
        Thread t = new Thread(m);

        MyThread m1 = new MyThread("ming");
        Thread t1 = new Thread(m1);
        t.setPriority(Thread.MAX_PRIORITY);
        t1.setPriority(Thread.MIN_PRIORITY);
        int y = t.getPriority();
        int y1 = t1.getPriority();
        System.out.println("Allen线程优先级"+y);
        System.out.println("ming线程优先级"+y1);
        
        t.start();
        t1.start();

    }
}

线程同步

多线程运行时的问题:

  1. 各个线程是通过竞争CPU时间而获得运行机会的
  2. 各个线程什么时候得到CPU时间、占用多久,是不可预测的
  3. 一个正在运行着的线程在什么地方被暂停是不确定的

使用synchronized关键字加锁。同一时刻只能单个操作。

synchronized关键字可以用在:成员方法、静态方法、语句块

public synchronized void F(){}
public static synchronized void F(){}
synchronized (){}

线程间通信

Java中的线程通信和Python中的差不多,通过中间队列类存储,由消费者和生产者负责放入和取出。


img_c16ba0223efd205a45fa915cc26916cd.png
image.png

wait方法:中断方法的执行,使线程等待
notify方法:唤醒处于等待的某一个线程
notifyAll方法:唤醒处于等待的全部线程

小结

创建线程的两种方式:

  1. 继承Thread类创建线程 new Thread().start()
  2. 实现Runnable接口创建线程 new Thread(new MyRunable()).start()

线程的5种状态:

  1. 新建
  2. 可运行
  3. 运行
  4. 阻塞
  5. 终止

sleep、join、wait、notify、notifyAll方法:

线程优先级:

  • 最高、最低。
  • 获取优先级、设置优先级。
  • 先启动的线程尽管优先级低,也会可能先执行。

线程同步:
synchronized关键字,可以用在:成员方法、静态方法、语句块。

上述文章如有帮助记得点赞呦,关注后第一时间获得最新笔记,持续更新~

目录
相关文章
|
7天前
|
存储 缓存 安全
【Java面试题汇总】多线程、JUC、锁篇(2023版)
线程和进程的区别、CAS的ABA问题、AQS、哪些地方使用了CAS、怎么保证线程安全、线程同步方式、synchronized的用法及原理、Lock、volatile、线程的六个状态、ThreadLocal、线程通信方式、创建方式、两种创建线程池的方法、线程池设置合适的线程数、线程安全的集合?ConcurrentHashMap、JUC
【Java面试题汇总】多线程、JUC、锁篇(2023版)
|
1天前
|
缓存 Java 应用服务中间件
Java虚拟线程探究与性能解析
本文主要介绍了阿里云在Java-虚拟-线程任务中的新进展和技术细节。
|
3天前
|
Java
深入理解Java中的多线程编程
本文将探讨Java多线程编程的核心概念和技术,包括线程的创建与管理、同步机制以及并发工具类的应用。我们将通过实例分析,帮助读者更好地理解和应用Java多线程编程,提高程序的性能和响应能力。
15 4
|
11天前
|
Java 调度 开发者
Java并发编程:深入理解线程池
在Java的世界中,线程池是提升应用性能、实现高效并发处理的关键工具。本文将深入浅出地介绍线程池的核心概念、工作原理以及如何在实际应用中有效利用线程池来优化资源管理和任务调度。通过本文的学习,读者能够掌握线程池的基本使用技巧,并理解其背后的设计哲学。
|
2天前
|
安全 Java 调度
Java 并发编程中的线程安全和性能优化
本文将深入探讨Java并发编程中的关键概念,包括线程安全、同步机制以及性能优化。我们将从基础入手,逐步解析高级技术,并通过实例展示如何在实际开发中应用这些知识。阅读完本文后,读者将对如何在多线程环境中编写高效且安全的Java代码有一个全面的了解。
|
11天前
|
缓存 监控 Java
Java中的并发编程:理解并应用线程池
在Java的并发编程中,线程池是提高应用程序性能的关键工具。本文将深入探讨如何有效利用线程池来管理资源、提升效率和简化代码结构。我们将从基础概念出发,逐步介绍线程池的配置、使用场景以及最佳实践,帮助开发者更好地掌握并发编程的核心技巧。
|
7天前
|
Java 调度 开发者
Java中的多线程基础及其应用
【9月更文挑战第13天】本文将深入探讨Java中的多线程概念,从基本理论到实际应用,带你一步步了解如何有效使用多线程来提升程序的性能。我们将通过实际代码示例,展示如何在Java中创建和管理线程,以及如何利用线程池优化资源管理。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的见解和技巧,帮助你更好地理解和应用多线程编程。
|
12天前
|
缓存 监控 Java
java中线程池的使用
java中线程池的使用
|
12天前
|
算法 Java 数据处理
Java并发编程:解锁多线程的力量
在Java的世界里,掌握并发编程是提升应用性能和响应能力的关键。本文将深入浅出地探讨如何利用Java的多线程特性来优化程序执行效率,从基础的线程创建到高级的并发工具类使用,带领读者一步步解锁Java并发编程的奥秘。你将学习到如何避免常见的并发陷阱,并实际应用这些知识来解决现实世界的问题。让我们一起开启高效编码的旅程吧!
|
17天前
|
存储 Java 程序员
优化Java多线程应用:是创建Thread对象直接调用start()方法?还是用个变量调用?
这篇文章探讨了Java中两种创建和启动线程的方法,并分析了它们的区别。作者建议直接调用 `Thread` 对象的 `start()` 方法,而非保持强引用,以避免内存泄漏、简化线程生命周期管理,并减少不必要的线程控制。文章详细解释了这种方法在使用 `ThreadLocal` 时的优势,并提供了代码示例。作者洛小豆,文章来源于稀土掘金。