当前位置: 首页 > news >正文

Java中的多线程

文章目录

  • Java中的多线程
    • 一、引言
    • 二、多线程的创建和启动
      • 1、继承Thread类
      • 2、实现Runnable接口
    • 三、线程的常用方法
      • 1、currentThread()和getName()
      • 2、sleep()和yield()
      • 3、join()
    • 四、线程优先级
    • 五、使用示例
    • 六、总结

Java中的多线程

一、引言

在Java中,多线程编程是一种常见的并发执行技术,它允许程序同时执行多个任务。多线程可以提高程序的效率和响应性,特别是在需要执行长时间运行的任务或多个任务时。本文将详细介绍Java中多线程的基本概念、创建方式以及一些常用的线程操作方法。

二、多线程的创建和启动

1、继承Thread类

创建多线程的一种方式是让自定义的类继承Thread类,并重写其run方法。这种方式简单直观,但存在单继承的局限性。

class MyThread extends Thread {@Overridepublic void run() {for (int i = 0; i < 100; i++) {if (i % 2 == 0) {System.out.println(Thread.currentThread().getName() + ": " + i);}}}
}public class ThreadTest {public static void main(String[] args) {MyThread t1 = new MyThread();t1.start(); // 启动线程}
}

2、实现Runnable接口

另一种创建多线程的方式是实现Runnable接口,这种方式避免了单继承的局限性,并且更适合多个线程共享数据。

class MyRunnable implements Runnable {@Overridepublic void run() {for (int i = 0; i < 100; i++) {System.out.println(Thread.currentThread().getName() + " --> " + i);}}
}public class RunnableTest {public static void main(String[] args) {Thread t1 = new Thread(new MyRunnable());t1.start(); // 启动线程}
}

三、线程的常用方法

1、currentThread()和getName()

currentThread()方法返回当前代码执行的线程对象,getName()方法用于获取当前线程的名字。

Thread.currentThread().getName(); // 获取当前线程名

2、sleep()和yield()

sleep()方法让当前线程暂停执行指定的时间,而yield()方法则是让出当前线程的CPU执行权,允许其他线程执行。

try {Thread.sleep(1000); // 暂停1秒
} catch (InterruptedException e) {e.printStackTrace();
}Thread.yield(); // 让出CPU执行权

3、join()

join()方法用于等待一个线程终止。这在需要确保某个线程执行完毕后再继续执行主线程的情况下非常有用。

Thread t2 = new Thread(new MyRunnable());
t2.start();
try {t2.join(); // 等待t2线程执行完毕
} catch (InterruptedException e) {e.printStackTrace();
}

四、线程优先级

线程优先级是一个整数,其值从Thread.MIN_PRIORITY(1)到Thread.MAX_PRIORITY(10)。默认情况下,线程的优先级是Thread.NORM_PRIORITY(5)。高优先级的线程更有可能被操作系统选中执行,但这并不保证高优先级线程会先于低优先级线程执行完毕。

Thread t = new Thread(new MyRunnable());
t.setPriority(Thread.MAX_PRIORITY); // 设置最高优先级
t.start();

五、使用示例

下面是一个实际的多线程使用示例,模拟了两个线程交替打印数字的场景:

public class Counter {private int count = 0;public void increment() {count++;}public int getCount() {return count;}
}class ThreadA extends Thread {private Counter counter;public ThreadA(Counter counter) {this.counter = counter;}@Overridepublic void run() {for (int i = 0; i < 100; i++) {counter.increment();System.out.println("A: " + counter.getCount());}}
}class ThreadB extends Thread {private Counter counter;public ThreadB(Counter counter) {this.counter = counter;}@Overridepublic void run() {for (int i = 0; i < 100; i++) {counter.increment();System.out.println("B: " + counter.getCount());}}
}public class Main {public static void main(String[] args) {Counter counter = new Counter();ThreadA threadA = new ThreadA(counter);ThreadB threadB = new ThreadB(counter);threadA.start();threadB.start();}
}

在这个示例中,Counter类用于计数,ThreadAThreadB是两个线程,它们共享同一个Counter实例,并交替执行以增加计数器的值。主方法main中创建了Counter对象和两个线程对象,并启动它们。这个示例展示了多线程在实际应用中的简单用法,以及如何共享资源(这里是Counter对象)。

六、总结

Java中的多线程编程是一个强大的工具,它可以帮助我们提高程序的效率和响应性。通过继承Thread类或实现Runnable接口,我们可以创建和管理线程。了解线程的常用方法和优先级设置,可以帮助我们更好地控制线程的行为和执行顺序。多线程编程也需要我们注意线程安全问题,避免数据竞争和死锁等问题。


版权声明:本博客内容为原创,转载请保留原文链接及作者信息。

参考文章

  • Java多线程(超详细+大量代码)-阿里云开发者社区
http://www.lryc.cn/news/492232.html

相关文章:

  • 什么是聚簇索引、非聚簇索引、回表查询
  • 探索 Spring 框架核心组件:构建强大 Java 应用的基石
  • Android 13 Aosp 默认允许应用动态权限
  • 【C++知识总结1】c++第一篇,简单了解一下命名空间是什么
  • 从0开始深度学习(32)——循环神经网络的从零开始实现
  • GitLab使用操作v1.0
  • cuda conda yolov11 环境搭建
  • 解决SpringBoot连接Websocket报:请求路径 404 No static resource websocket.
  • element-plus的组件数据配置化封装 - table
  • 【二维动态规划:交错字符串】
  • goframe开发一个企业网站 MongoDB 完整工具包18
  • 在vue中,根据后端接口返回的文件流实现word文件弹窗预览
  • 动态规划之背包问题
  • 【Python】 深入理解Python的单元测试:用unittest和pytest进行测试驱动开发
  • Java集合1.0
  • Leetcode 336 回文对
  • 实现一个可配置的TCP设备模拟器,支持交互和解析配置
  • 算法的空间复杂度
  • 自定义协议
  • 在 Taro 中实现系统主题适配:亮/暗模式
  • autogen框架中使用chatglm4模型实现react
  • 读《Effective Java》笔记 - 条目9
  • 【软件入门】Git快速入门
  • nextjs window is not defined
  • C语言实现冒泡排序:从基础到优化全解析
  • windows11下git与 openssl要注意的问题
  • lua除法bug
  • Ubuntu下Docker容器java服务往mysql插入中文数据乱码
  • C语言根据字符串变量获取/设置结构体成员值
  • Selenium 自动化测试demo