【JavaEE】线程的概念

embedded/2024/10/22 10:43:41/

文章目录

  • 1、什么是线程
  • 2、进程和线程的区别
  • 3、多线程的概述
  • 4、在Java中实现多线程的方法
    • 1.继承Thread类
    • 2.实现Runnable接口
    • 3.使用匿名内部类来继承Thread类,实现run方法
    • 4.使用匿名内部类来实现Runnable接口,实现run方法
    • 5.使用 lambda表达式


1、什么是线程

线程是进程中实际执行的最小单位,在一个进程中,可以存在一个或者多个线程,同一个进程中的若干线程之间,是共用相同的内存资源和文件资源,线程是系统调度执行的基本单位
利用线程可以解决进程创建/销毁开销大的问题
线程thread也被称为 “轻量级进程” 创建/销毁开销小
线程比进程更轻量,核心在于创建进程可能要包含多个线程,在这个过程中涉及到资源分配/资源释放,创建线程相当于资源已经有了,省去了资源分配/释放步骤
描述进程,使用的PCB这样的结构体,事实上更严格的说,一个PCB其实描述一个线程,若干个PCB联合在一起,是描述一个进程的

2、进程和线程的区别

1.进程是包含线程的,每一个进程至少有一个线程存在,即主线程
2.进程和线程之间不共享内存空间,同一个进程的线程之间共享同一个内存空间
3.进程是系统分配资源的最小单位,线程是系统调度的最小单位
4.一个进程挂了一般不影响其他进程,但是一个线程挂了,可能把同进程内的其他线程一起带走(整个进程崩溃)

3、多线程的概述

多线程是指在一个程序中同时执行多个线程,每个线程可以独立执行不同的任务或者操作,在Java中,多线程可以让程序更高效的利用计算机的多核处理器,提高程序的性能和响应速度,多个线程之间都是并发执行的

4、在Java中实现多线程的方法

1.继承Thread类

创建一个类继承Thread类,重写里面的run方法,这里的run方法描述了线程具体要干些什么在主函数中用start方法启动,这样就创建了一个线程,在调用start方法之后,系统会自动调用重写的run方法,也就是回调函数,交给系统执行run方法

java">class MyThread extends Thread {@Overridepublic void run() {while (true) {System.out.println("hello thread");}}
}
public class Test {public static void main(String[] args) {Thread thread = new MyThread();thread.start();while (true) {System.out.println("hello main");}}
}

运行结果:
在这里插入图片描述
在main中有一个线程,我们称为主线程,主线程是自动创建的,而thread线程是我们手动创建的
多线程的调度顺序是无序的,在操作系统内部也称为“抢占式执行”,任何一个线程,在执行到任何一个代码的过程中,都可以被其它线程抢占掉它的cpu资源,于是cpu就给别的下次执行了,
在这里我们还可以使用 jconsole.exe 这个应用程序,来观察这个多线程代码:
在这里插入图片描述
在这里插入图片描述
点击连接,进入页面之后再点击线程就可以了
在这里插入图片描述
上图表示有多少个线程
在这里插入图片描述
上图圈起来的就表示我们创建的两个线程
剩下的线程都是jvm帮我们做的一些其他工作,涉及到的负责垃圾回收,负责记录调试信息等

2.实现Runnable接口

创建一个类实现Runnable接口,并重写run方法

java">class MyRunnable implements Runnable {@Overridepublic void run() {while (true) {System.out.println("hello thread");}
}
public class Test2 {public static void main(String[] args) {Thread t = new Thread(new MyRunnable());t.start();while (true) {System.out.println("hello main");}}
}

3.使用匿名内部类来继承Thread类,实现run方法

java">public class Test3 {public static void main(String[] args) {new Thread() {@Overridepublic void run() {while (true) {System.out.println("hello thread");}}}.start();while (true) {System.out.println("hello main");}}
}

4.使用匿名内部类来实现Runnable接口,实现run方法

java">public class Test4 {public static void main(String[] args) {Thread thread = new Thread(new Runnable() {@Overridepublic void run() {while (true) {System.out.println("hello thread");}}});thread.start();while (true) {System.out.println("hello main");            }}
}

5.使用 lambda表达式

java">public class Test5 {public static void main(String[] args) {Thread thread = new Thread(()-> {while (true) {System.out.println("hello thread");                }});//创建线程 启动线程thread.start();while (true) {System.out.println("hello main");            }}
}

http://www.ppmy.cn/embedded/33648.html

相关文章

【Java】基本程序设计结构(一)

前言:现在,假定已经成功安装了JDK,并且能够运行上篇示例程序。本篇将开始介绍Java程序中的基本设计结构,其中包括:一个简单的Java应用,注释,数据类型,变量与常量,运算符&…

正则化回归

1. L1正则化 L1正则化是回归参数各个元素绝对值之和。 2. L2正则化 L2正则化是回归参数各个元素平方之和。 3.LOSS回归 线性回归加上L1正则化 4.岭回归 线性回归加上L2正则化 不断增大 L2 约束项参数 α,可以发现岭回归参数优化解不断靠近原点&#xff0c…

谈谈TCP/IP体系结构、TCP的标志位以及TCP协议的可靠性

TCP/IP 传输控制协议(TCP,Transmission Control Protocol)是一种面向连接的、可靠的、基于字节流的传输层通信协议,是一个工业标准的协议集,它是为广域网(WANs)设计的,连接是全双工的…

简单的知识蒸馏

import os os.environ[TF_CPP_MIN_LOG_LEVEL] 2 os.environ["KERAS_BACKEND"] "tensorflow" os.environ[HF_ENDPOINT] https://hf-mirror.com import keras from keras import layers from keras import ops import numpy as np # 随着训练的进行&…

Redis-分片机制

概述 业务需要:由于单台redis内存容量是有限的,无法实现海量的数据实现缓存存储 概念:由多个redis节点协助工作的机制就是redis的分片机制 作用:为了实现redis扩容 特点:分片机制把该机制中包含的多台redis缓存服务…

【前端学习——css】css实现给背景的图片加模糊

我在制作自己的博客的时候,打算做个封面,封面用半透明颜色盖住了预览图,上面印上了文字,但背景图太乱了,所以打算给背景加模糊效果。 效果 方法 主要就是利用这个属性 backdrop-filter: blur(5px);属性很简单&#x…

基于纯JavaScript实现的MODBUS-RTU(串口和TCP) modbus-serial

modbus-serial 如果你需要使用JavaScript来操作一台RS458的设备,那么你一定不能错过这个库 modbus-serial。 安装和使用 npm install modbus-serial支持的功能码 功能码函数FC1 读取读线圈寄存器readCoils(coil, len) FC2 读离散输入寄存器readDiscreteInputs(a…

C语言实战项目--贪吃蛇

贪吃蛇是久负盛名的游戏之一,它也和俄罗斯⽅块,扫雷等游戏位列经典游戏的行列。在编程语言的教学中,我们以贪吃蛇为例,从设计到代码实现来提升大家的编程能⼒和逻辑能⼒。 在本篇讲解中,我们会看到很多陌生的知识&…