首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏王磊的博客

    面试官:什么是虚拟线程?为什么要有虚拟线程

    Java 中的虚拟线程,也叫做协程或“轻量级线程”,它诞生于 JDK 19(预览 API),正式发布于 JDK 21,它是一种在 Java 虚拟机(JVM)层面实现的逻辑线程,不直接和操作系统的物理线程一一对应 操作系统线程、普通线程(Java 线程)和虚拟线程的关系如下:虚拟线程使用虚拟线程的创建方式,主要有以下 4 种:Thread.startVirtualThread(Runnable task)Thread.ofVirtual (()->{ System.out.println("Do virtual thread.");});// 运行虚拟线程vt.start();3.factory先创建虚拟线程工厂,然后再使用工厂创建虚拟线程 普通线程默认创建的是用户线程(而守护线程),而虚拟线程是守护线程,并且其守护线程的属性不能被修改,如果修改就会报错,如下图所示:虚拟线程由 JVM 调度和使用,避免了普通线程频繁切换的性能开销,所以相比于普通的线程来说 小结线程是轻量级的进程,而虚拟线程则是轻量级的线程虚拟线程是 JVM 层面实现的逻辑线程,不直接和操作系统的物理线程一一对应,因此使用它可以减少线程上下文切换所带来的性能开销。

    1.1K10编辑于 2023-12-20
  • 来自专栏技术分享

    JDK23--虚拟线程

    Java23下载地址:https://www.oracle.com/cn/java/technologies/downloads/虚拟线程的特点 轻量级每个虚拟线程的创建和销毁成本非常低,可与协程的成本相媲美 阻塞与非阻塞兼容 虚拟线程支持阻塞式代码风格,即便线程处于阻塞状态,也不会浪费操作系统资源,因为虚拟线程在阻塞时会自动挂起并释放底层资源。同时兼容现有的非阻塞 I/O,开发者无需改变已有的代码习惯。 透明性 使用虚拟线程无需学习新的 API,开发者可以像使用传统线程一样简单地操作虚拟线程。 每个虚拟线程可以由一个或多个操作系统线程动态映射和执行,从而提升资源利用率。虚拟线程的应用场景 高并发网络应用 适用于需要处理大量用户请求的服务器,例如 Web 服务、聊天系统等。 如何使用虚拟线程从 JDK 19 开始,虚拟线程作为预览特性引入,JDK 21 及之后版本正式稳定。

    53620编辑于 2025-01-10
  • 来自专栏FunTester

    Spring WebClient + 虚拟线程实战

    Spring WebClient 与虚拟线程:实战集成指南 在上一篇文章中,我们介绍了 JDK HttpClient 和虚拟线程的基础概念。 与 Spring WebClient 集成 你也可以增强 Spring WebClient,使其使用虚拟线程,将 Spring 强大的生态系统与虚拟线程的可扩展性结合起来。 这样你既能享受 Spring 的便利,又能获得虚拟线程的性能优势。 虚拟线程消除了简单性(每个请求一个线程)与可扩展性之间的传统权衡。 虚拟线程使这种模式高效且简单。

    23910编辑于 2025-12-21
  • 来自专栏猫头虎博客专区

    虚拟线程(Virtual Threads):什么是JDK 21中的虚拟线程?如何实现轻量级线程管理?

    启用虚拟线程的环境要求 虚拟线程是JDK 21正式发布的新特性,确保以下环境支持: JDK 21及以上版本。 --enable-preview 标志以启用虚拟线程。 2. } } 输出结果(部分示意): 执行任务 1,线程名: VirtualThread-1 执行任务 2,线程名: VirtualThread-2 执行任务 3线程名: VirtualThread -3 ... 说明: 高并发能力:虚拟线程池可同时执行大量任务,无需担心线程数量限制。 轻量级管理:每个任务对应一个虚拟线程,系统资源占用极低。 3. A:虚拟线程适合高并发任务,但在一些场景(如与本地代码交互、计算密集型任务)仍需使用传统线程。 Q:虚拟线程是否线程安全?

    2.4K11编辑于 2024-12-20
  • 来自专栏得物技术

    虚拟线程原理及性能分析

    载体线程(Carrier Thread):指真正负责执行虚拟线程中任务的平台线程。一个虚拟线程装载到一个平台线程之后,那么这个平台线程就被称为虚拟线程的载体线程。 **这意味着许多虚拟线程可以在同一个平台线程上运行他们的 Java 代码,共享同一个平台线程。**同时虚拟线程的成本很低,虚拟线程的数量可以比平台线程的数量大得多。 unmount 操作:虚拟线程从平台线程卸载,此时虚拟线程的任务还没有执行完成,所以虚拟线程中包装的 Continuation 栈数据帧会会留在堆内存中。 从 Java 代码的角度来看,其实是看不到虚拟线程及载体线程共享操作系统线程的,会认为虚拟线程及其载体都在同一个线程上运行,因此,在同一虚拟线程上多次调用的代码可能会在每次调用时挂载的载体线程都不一样。 一个虚拟线程被分配平台线程,该平台线程作为载体线程执行虚拟线程中的任务。虚拟线程运行其 Continuation,Mount(挂载)平台线程后,最终执行 Runnable 包装的用户实际任务。

    1.8K41编辑于 2023-12-06
  • 来自专栏余林丰

    虚拟机类加载机制(3)——线程上下文类加载器

    之所以将线程上下文类加载器(Thread Context ClassLoader)单独拿出来写,确实是因为它涉及的东西比较多,既然带有线程两个字,一定也是非常重要的一个东西。 image.png 在上一章《虚拟机类加载机制(2)——类加载器》中我们解释了何为类加载器的“双亲委派模型”,知道了双亲委派模型给我们带了一个好处就是Java类随着它的类一起具备了一种带有优先级的层次关系 setContextClassLoader(ClassLoader cl)方法用来获取和设置上下文类加载器,如果没有setContextClassLoader(ClassLoader cl)方法通过设置类加载器,那么线程将继承父线程的上下文类加载器 通过线程上下文来加载第三方库jndi实现,而不依赖于双亲委派。 虚拟机的这几个部分确实有难度,本人经验知识有限也在努力学习中,尚不能给出专业且详尽的分析,这里有一篇介绍上下文类加载的文章可以研读此文。

    1K70发布于 2018-01-09
  • 来自专栏芋道源码

    SpringBoot 物理线程虚拟线程、Webflux 性能全面对比!

    介绍 在本文中,我们将深入探讨所有同级产品之间的友好比较,即具有「物理线程虚拟线程和 Webflux 的 SpringBoot」 ,重点关注它们在特定用例场景中的性能。 —它在虚拟线程而不是传统的物理线程上运行。 虚拟线程是并发领域的游戏规则改变者。这些轻量级线程简化了开发、维护和调试高吞吐量并发应用程序的复杂任务。 虽然虚拟线程仍然在底层操作系统线程上运行,但它们带来了显着的效率改进。 当虚拟线程遇到阻塞 I/O 操作时,Java 运行时会暂时挂起它,从而释放关联的操作系统线程来为其他虚拟线程提供服务。这个优雅的解决方案优化了资源分配并增强了整体应用程序响应能力。 、虚拟线程和 Webflux 进行友好性能评估的背景下,了解关键的数据关系至关重要。

    97000编辑于 2025-05-10
  • 来自专栏CodeNone

    【多线程线程池源码(3

    2.3 监控线程池状态的线程 在一开始也普及过了线程池中相关的一些参数,通过下面这个监视线程能更加直观的了解这些参数 public class MonitorThread implements Runnable ,但是在线程池里面其实是看作一个任务,线程池会创建核心线程来执行这个任务(逻辑是这个线程里面的run()方法)。 args) throws InterruptedException { MyThreadPoolExecutor executor = new MyThreadPoolExecutor(3,5 , 30, TimeUnit.SECONDS, new ArrayBlockingQueue<Runnable>(3), new MyRejectedExecutionHandler()); executor.shutdown(); Thread.sleep(3000); monitorThread.stopMonitor(); } } 3

    39820发布于 2021-08-10
  • 来自专栏Android知识点总结

    线程3

    1)内存中读取i的值,2)i=i+1,3)将结果写回内存 i=9时,若线程2已经在第三步了,但还没写入内存。 感觉有点...麻烦 1.两个线程访问一个对象的普通同步方法 2.两个线程访问两个对象的普通同步方法 3.两个线程访问静态同步方法 4.两个线程分别访问普通同步方法和非同步方法 5.两个线程分别访问一个对象的不同普通同步方法 6.两个线程分别访问静态同步和非静态同步方法 方法抛出异常后,会释放锁 ---- 1.两个线程访问一个对象的普通同步方法 二-->2中的例子:线程1,2访问一个对象instance的同步方法:sleep3ms ,对于两个线程而言,同步是无用的 ---- 3.两个线程访问静态同步方法 二-->3-->3.1第二个小例子,轻轻加了个static 由于静态同步方法的锁是class,锁对该类的所有对象都有效 ---- 2.如何:线程1的修改被线程2看到 1.工作内存1操作共享变量a后刷新到主内存 2.然后线程2从主内存中读取共享变量a值并拷贝到自己的工作内存 ---- 3、synchronized实现可见性

    37330编辑于 2022-09-20
  • 来自专栏实战docker

    支持JDK19虚拟线程的web框架,之三:观察运行中的虚拟线程

    :体验 支持JDK19虚拟线程的web框架,之二:完整开发一个支持虚拟线程的quarkus应用 本篇概览 本篇是《支持JDK19虚拟线程的web框架》系列的第三篇,在前面两篇咱们一起了解和体验了支持虚拟线程的 web服务,功能性能都试过,整个开发过程也完整执行,算是对quarkus和虚拟线程有了初步的了解,但也留下两个问题 虚拟线程和常规子线程的区别,究竟能不能看出来? 不使用虚拟线程时的线程状况 咱们先发请求到/pool/persons,也就是先不用虚拟线程,看看传统线程池响应web服务的时候,在JProfiler中是啥样的 像《上篇》那样,用K6压测接口/pool 相信您已经很清楚了吧,我觉得是这三样: 调度器,scheduler(ForkJoin线程池中的线程) 执行虚拟线程任务的真实线程,carrier 虚拟线程 现在开始压测吧,继续用k6,如下图,脚本中的地址要改成使用虚拟线程的 来完成虚拟线程中的任务,等到这些任务执行完毕,所有真实线程虚拟线程都被结束,不再存活 至此,借助JProfiler观察常规线程虚拟线程的实战就完成了,经过了这些理论结合实际的操作和分析,相信您对虚拟线程的认知已经更具体和全面

    84140编辑于 2022-11-03
  • 来自专栏Java核心技术图谱:原理·对比·避坑

    Java的多线程——多线程(3)线程安全

    3线程不安全的原因 3.1线程调度是随机的(抢占式执行) 这是线程安全问题的罪魁祸首 :线程的调度 随机调度使⼀个程序在多线程环境下,执行顺序存在很多的变数 既保障了count++的线程安全,又利用了循环的并发潜力,因此执行速度更快。 3. 外部加锁 为什么count++是串行的? 进行数据更新 3. 把数据写回到CPU 不保证原子性会给多线程带来什么问题 如果⼀个线程正在对一个变量操作,中途其他线程插入进来了,如果这个操作被打断了,结果就可能是错误的。 Java内存模型(JMM):Java虚拟机规范中定义了Java内存模型. 去前台取下快递 如果是在单线程情况下,JVM、CPU指令集会对其进行优化,比如,按1->3->2的方式执行,也是没问 题,可以少跑⼀次前台。

    39610编辑于 2025-12-22
  • 来自专栏架构狂人

    一文讲透虚拟线程

    虚拟线程和普通线程的区别 “虚拟线程,望文生义,它是“假”的,它不直接调度操作系统的线程,而是由 JVM 再提供一层线程的接口抽象,由普通线程调度,即一个普通的操作系统线程可以调度成千上万个虚拟线程虚拟线程比普通线程的消耗要小得多得多,在内存足够的情况下,我们甚至可以创建上百万的虚拟线程,这在之前(Java19 以前)是不可能的。 SpringBoot 使用虚拟线程 下面我们会在 SpringBoot 中使用虚拟线程,将默认的异步线程池和 http 处理线程池替换为虚拟线程,然后对比虚拟线程和普通线程的性能差异,你会发现差别就像马车换高铁 要在 SpringBoot 中使用虚拟线程很简单,增加如下配置即可: /** * 配置是用于稍后测试,spring.virtual-thread=true是使用虚拟线程,false时还是使用默认的普通线程 下面再看下虚拟线程的表现: 「虚拟线程耗时」: 可以看到即使是最大耗时,也保持在 100ms 以下,即线程等待时间显著的减少,虚拟线程更好的利用了系统资源。

    1.1K10编辑于 2024-07-16
  • 网易面试:SpringBoot如何开启虚拟线程

    虚拟线程是一种在 Java 虚拟机(JVM)层面实现的逻辑线程,不直接和操作系统的物理线程一一对应,因此它可以减少上下文切换所带来的性能开销。 操作系统线程、普通线程(Java 线程)和虚拟线程的关系如下:1.虚拟线程使用虚拟线程的创建有以下 4 种方式:Thread.startVirtualThread(Runnable task)Thread.ofVirtual 3.SpringBoot开启虚拟线程以最新版的 Spring Boot 3.x 为例,我们开启虚拟线程很简单,只需要在 Spring Boot 配置文件中设置“spring.threads.virtual.enabled PS:这里是虚拟线程执行器,不是虚拟线程池。 有了虚拟线程后还需要虚拟线程池吗?为什么?

    2K10编辑于 2024-06-12
  • 来自专栏朱永胜的私房菜

    JDK21更新内容:虚拟线程

    Virtual Threads(虚拟线程)是Java平台的一项新功能,它旨在改进Java中的并发编程模型。传统上,Java使用基于操作系统线程的并发模型,每个线程都需要分配一个操作系统线程来执行。 3. Virtual Threads的实现原理 Virtual Threads的实现依赖于Java虚拟机(JVM)的协作调度器和Fork/Join框架。 具体而言,当一个Java应用程序创建一个Virtual Thread时,JVM会为其分配一个虚拟线程(也称为轻量级线程)。这些虚拟线程由协作调度器管理,并在需要时与操作系统线程进行绑定。 协作调度器负责决定哪个虚拟线程可以运行以及何时切换虚拟线程。 Fork/Join框架是Virtual Threads的另一个关键组件。 它通过引入轻量级的虚拟线程,并利用协作调度器和Fork/Join框架来提供高效的并发执行。

    1.2K70编辑于 2023-09-25
  • 来自专栏FunTester

    JDK HttpClient 与虚拟线程入门指南

    简单来说,以前你要么写复杂的异步代码,要么忍受线程资源限制,现在虚拟线程让你鱼和熊掌兼得。 这就像传统线程是雇佣全职员工,成本高;虚拟线程是雇佣临时工,按需分配,成本低。 当将 JDK HttpClient 与虚拟线程集成时,魔法就发生了。 我们做了个基准测试,对 10,000 个并发 HTTP 请求进行测试,结果如下: • 传统平台线程:8-10 秒,2-3 GB 内存(资源消耗大,速度慢) • 响应式 WebFlux:3-4 秒,500 MB 内存(性能好,但代码复杂) • 虚拟线程 + HttpClient:3-4 秒,300 MB 内存(性能好,代码简单) 虚拟线程实现了响应式级别的性能,同时代码更易于阅读且是命令式的。

    24710编辑于 2025-12-21
  • 来自专栏wayn的程序开发

    2 分钟理解虚拟线程是什么

    (大家为了节约线程资源,也就有了线程池的概念) 什么是虚拟线程? 与平台线程一样,虚拟线程也是 java.lang.Thread 的一个实例对象。但是,虚拟线程并不依赖于特定的操作系统线程虚拟线程底层仍然在操作系统的线程上运行代码。 而在虚拟线程中调用阻塞 I/O 操作时,JVM 虽然也会挂起该虚拟线程,但是与平台线程不同的是,被挂起虚拟线程关联的操作系统线程是可以为其他虚拟线程继续服务的。 虚拟线程的实现方式与虚拟内存类似。 因此与平台线程消耗的资源很多不同,虚拟线程在使用时只需要很少的内存资源。单个 JVM 就可以轻松创建数百万个虚拟线程。 尽管虚拟线程支持线程局部变量和可继承的线程局部变量,但我们应该仔细考虑后再使用它们,因为单个 JVM 可能运行数百万个虚拟线程

    44300编辑于 2023-12-29
  • 来自专栏Vincent-yuan

    python3线程-线程异步

    python3有threading和_thread两种线程写法,推荐使用threading。 开多线程就是为了使用多线程的异步能力来同时执行多个线程。 1. threading方法: 以下代码可以执行异步或者同步线程。 1 import threading 2 import time 3 4 5 class my_thread(threading.Thread): 6 def __init__ 56 pass 57 58 59 index(False) # 同步线程True,异步线程False(推荐) 2. _thread方法(程序要求不高的话推荐这种老写法): 1 import _thread 2 3 4 all_thread_num = 0 5 6 7 def page_class

    72230编辑于 2022-05-06
  • 来自专栏∑小熊猫的博客

    Java 多线程系列(3) —— 守护线程

    守护线程 Java 中的线程分为两种,一种是用户线程,另一种是守护线程 用户线程: 平时的线程 守护线程: 为用户线程提供服务的线程 守护线程的特点: 守护线程创建的子线程依旧是守护线程 当守护线程所守护的用户线程全部结束时 ,守护线程会自动关闭 如何设置守护线程 在 Java 中,守护线程的设置非常简单,我们只需要调用 Thread 类的 setDaemo(true) 就行。 同时我们也可以使用 isDaemon() 方法来查看一个线程是否是守护线程。 【示例】 守护线程示例 public class ThreadDaemon implements Runnable { @Override public void run() { int public class DemoTest { /** * 守护线程的 Demo */ @Test public void test1() { ThreadDeamo td =

    55420发布于 2020-12-02
  • 来自专栏java小记

    java多线程学习(3)-线程

    简介 随着并发的增多,创建、销毁线程的动作也随之增多,所以资源的浪费也随之增多,并且线程的数量变大,管理的难度也会随之加大------于是线程池小伙伴就出来前言 线程池的几个好处 降低资源消耗。 通过重复利用已创建的线程降低线程创建和销毁造成的消耗。 提高响应速度。当任务到达时,任务可以不需要的等到线程创建就能立即执行。 提高线程的可管理性。 ,也叫核心线程池,一般活动的线程数量不会超过此参数的大小; maximumPoolSize:当前线程池允许创建的最大线程数; keepAliveTime:线程活动保持时间,当线程空闲下来时,控制线程存活的时间 线程池执行的原理 线程池流程分析 当线程池当中有新提交的任务时,判断流程如下: 基本线程池是否满了? 没满,创建工作线程执行任务,满了,继续下面的判断 判断工作队列是否满了?没满,放入工作队列等待执行,满了,向下执行 判断线程池是否达到最大线程数?

    42730发布于 2018-07-25
  • 来自专栏网优小兵玩Python

    Python 3线程

    什么是线程 ---- 线程是操作系统能够进行运算调度的最小单位 包含在进程中,是进程中的实际运算单位 一个进程中可以并发多个线程,每个线程可执行不同任务 多线程类似于同时执行多个不同程序 优点一:时间长任务放到后台处理 )) #执行线程 t1.start() t2.start() #线程同步 t1.join() t2.join() ? 线程池运用 ---- 线程与进程一样可通过线程池来管理多线程 ThreadPoolExecutor实现线程池 from concurrent.futures import ThreadPoolExecutor #定义多线程执行函数 def test(name,i): print('线程'+name+'执行:',i) #创建多个线程 thre_name = [] #定义线程池变量 th_pool CPU内核 CPU密集型操作时不推荐使用多线程,建议使用多进程 IO密集型操作,多线程可明显提高效率 多线程与‘爬虫’可完美结合

    58620发布于 2019-10-22
领券