首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏Swift-开源分析

    结构化并发

    本篇提议引入 Swift 中对结构化并发的支持,使用提高工效、可预测并允许高效实现的模型,来实现异步代码的并发执行。 结构化并发 任何并发系统必须提供基础工具。必须有某种方法创建与现有线程并发运行的新线程,也必须有某种方法让线程等待另一个线程发出继续的信号。这都是很强大的工具,你可以用它们来写非常复杂的系统。 但是这是个临时的解决方案,而且需要在每个想使用并发的函数内重复使用。 结构化并发通过要求程序员组织他们的并发用法到高级任务和及其子组件任务里来解决上述问题。 提议的解决方案 我们提议的解决方案遵循上述结构化并发规则。所有异步函数都做为异步任务的一部分运行。任务可以产生并发执行的子任务。 这确保结构化并发的结构得到维护,而且这不仅可以更容易去推断在给定的作用域内正在执行的并发任务,而且也为编译器和运行时提供了更多的优化机会。

    3.6K40编辑于 2022-01-20
  • 来自专栏Linyb极客之路

    基于虚拟线程的结构化并发

    在本文中,我们将讨论并发系统的一些新模式,这些模式是由 Java 21 中的新虚拟线程、结构化并发 (JEP 453 )和范围值(JEP 446: Scoped Values)组成的新的结构化并发模式。 结构化并发 (JEP 453 )和范围值(JEP 446)这两个新 API 中的第一个称为“结构化并发”。 结构化并发 相比之下,结构化并发是为任务并行问题而设计的,其中涉及需要并行处理的不同但相关的子任务。API 与虚拟线程的密切关系意味着它主要适用于涉及一定量 I/O 的任务(尤其是对远程服务的调用)。 结构化并发任务的一般流程如下所示: 创建任务作用域范围——创建线程拥有该范围(上下文)。 在作用域内分叉并发子任务(每个子任务都是一个虚拟线程)。 范围值/作用域值Scoped Values 除了结构化并发(Structured Concurrency)之外,新的范围值 API(Scoped Values API)也作为预览版出现在 Java 21

    65620编辑于 2023-11-07
  • 来自专栏编译器

    Go语言中有没有结构化并发

    本文原文地址在本博主博客,点击链接前往:Go语言中有没有结构化并发?图片什么是结构化并发? 今天这篇文章要介绍的是结构化并发,就是为解决并发编程中线程并发任务管理,传统的方式非常容易造成管理混乱。 结构化并发设计在上面我介绍了一些关于非结构化并发的程序设计问题,如果单独创建协程没有做好错误处理或者异常情况下的处理,可能就会出现协程泄露问题,这就是本节要讲的结构化并发来做的并发控制设计。 小结我个人认为结构化并发是未来的并发和并行程序设计方向,现在有结构化并发程序设计的语言Kotlin、Java、Swift等,Rust语言中也有这方面相关第三方实现目前还不够完善。 解决并发编程之痛的良药:Rust结构化并发编程Go 中的分段栈和连续栈的区别?CPU眼里的:goto;因为强大,所以消失!译】「结构化并发」简析 或:有害的go语句

    92740编辑于 2022-09-15
  • 来自专栏深度学习与python

    JDK 21中的结构化并发并发编程的一次飞跃

    这个最初的预览特性来源于一个孵化 API,它根据前两轮的孵化纳入了一些改进,这两轮孵化分别是 JDK 19 交付的 JEP 428,结构化并发(孵化)和 JDK 20 交付的 JEP 437,结构化并发 JDK 21 中的结构化并发致力于引入结构化并发的 API 来简化并发编程。这种方法将在不同线程中运行的相关任务组视为一个工作单元,从而简化了错误处理和取消,提高了可靠性,并增强了可观测性。 结构化并发是一个预览 API,默认是禁用的。 它的目的也不是为 Java 平台定义明确的结构化并发 API,或在线程间共享数据流的方法。 这些模型不会强制要求或跟踪任务和子任务之间的关系,使得并发任务的管理和可观测性很具挑战性。 结构化并发提出,任务结构应该反映代码结构。

    77840编辑于 2023-08-09
  • 结构化并发才是王道!

    我们直接运行代码看结果: 我们先看一段结构化并发的Demo代码: 获取用户信息任务为(执行3秒): 此时运行代码,应该两个子任务都不会抛异常,所以都能正常的执行,得到的结果为: 如果把ShutdownOnFailure StructuredTask就执行结束了,所以获取用户信息任务就不会执行了(只执行了开头,相当于任务中止了),输出结果为: 从中可以看出,ShutdownOnFailure和ShutdownOnSuccess就是结构化并发的精髓 ,那为什么叫结构化并发呢? 我个人的理解是通过结构化并发,可以将多个并发子任务组合成一个大任务,并且这个大任务可以控制子任务的执行进度,就算子任务已经开始执行了也可以被中止。 好了,你是怎么理解结构化并发的呢?说说你的理解。

    15710编辑于 2024-03-07
  • 来自专栏golang从入门到进阶

    Go 结构化并发:给 goroutine 装上“安全带“

    先讲个生活故事:放风筝vs开团队想象你在组织一次团队活动:❌无结构化并发(Go原生go)展开代码语言:TXTAI代码解释你:大家分头去采购! A:我去买菜(转身就走)B:我去买饮料(转身就走)C:我去买餐具(转身就走)10分钟后...你:人呢?谁回来了?谁出问题了? ✅结构化并发展开代码语言:TXTAI代码解释你:大家分头采购,30分钟后门口集合,谁有问题随时喊我!A/B/C:收到! 这就是StructuredConcurrency(结构化并发)要解决的问题。什么是结构化并发? 为什么Go不内置结构化并发

    12310编辑于 2026-03-13
  • 来自专栏深度学习与python

    JEP 428:结构化并发,简化 Java 多线程编程

    作者 | A N M Bazlur Rahman 译者 | 明知山 策划 | 丁晓昀 JEP 428,即结构化并发 (孵化器阶段),已经从 Proposed 状态进入到 Target 状态。 所以,它们是非结构化并发代码。 通过观察非结构化并发代码存在的这些问题,Martin Sústrik 在他的博文中创造了“结构化并发”这个术语,然后 Nathaniel J. Smith 在他关于结构化并发的文章中推广了这个术语。 关于结构化并发,Oracle 技术咨询成员、Loom 项目负责人 Ron Pressler 在 InfoQ 的一个播客中说道: 结构化的意思是,如果你生成了什么东西,你必须等待并连接它。 这里的“结构”与它在结构化编程中的含义相似。代码的块结构反映了程序的运行时行为。因此,就像结构化编程提供了顺序控制流保证,结构化并发也为并发提供了同样的保证。

    69910编辑于 2023-03-29
  • 来自专栏Linyb极客之路

    从任务到线程:Java结构化并发应用程序

    并发设计的本质,就是要把程序的逻辑分解为多个任务,这些任务独立而又协作的完成程序的功能。而其中最关键的地方就是如何将逻辑上的任务分配到实际的线程中去执行。 在线程中执行任务 并发程序设计的第一步就是要划分任务的边界,理想情况下就是所有的任务都独立的:每个任务都是不依赖于其他任务的状态,结果和边界。因为独立的任务是最有利于并发设计的。 while (true) { final Socket connection = socket.accept(); //为每个请求创建单独的线程任务,保证并发性 使得主线程不用等待任务完毕就可以去快速地去响应下一个请求,以达到高响应速度; 任务处理可以并行,支持同时处理多个请求; 任务处理是线程安全的,因为每个任务都是独立的 不过需要注意的是,任务必须是线程安全的,否者多线程并发时会有问题 既然是并发处理,当然会遇到一次性提交一组任务的情况,这个时候可以使用CompletionService,CompletionService可以理解为Executor和BlockingQueue的组合:当一组任务被提交后

    72920发布于 2018-12-07
  • 来自专栏Java 技术小屋

    聊聊 Java 21 中的结构化并发(预览版)

    结构化并发在开始了解结构化并发前,我们先回顾一下 Java 中非结构化并发的写法。 结构化并发在单线程编程模型中,编程语言 通过代码块避免控制流随意跳转,从而实现程序的结构化。 但在多线程编程(并发编程)模型中,线程之间控制和归属关系仍然存在很多问题,其面临的问题与 GOTO 的问题非常相似,这也是结构化并发所要解决的问题。什么是结构化并发呢? 下面是非结构化并发(图一)和结构化并发(图二)的运行示例图:Java 结构化并发示例public class Test { public static void main(String[] args 提高并发代码的可观察性。以下不是目前非结构化并发的目标不会替换现有的任务并发结构。

    78530编辑于 2023-11-08
  • 来自专栏用户2276240的专栏(5)

    Java 19 中的结构化并发-Java快速进阶教程

    概述 在本教程中,我们将讨论孵化器功能结构化并发 (JEP 428),它为 Java 19 提供了结构化并发功能。我们将指导你使用新的 API 来管理多线程代码。 2. 为了更好地理解非结构化并发的问题,让我们看一个例子: Future<Shelter> shelter; Future<List<Dog>> dogs; try (ExecutorService executorService 结构化并发试图解决这些问题,我们将在下一章中看到。 3. 示例 对于结构化并发示例,我们将使用以下记录: record Shelter(String name) { } record Dog(String name) { } record Response 元素列表: private List<Dog> getDogs() { return List.of(new Dog("Buddy"), new Dog("Simba")); }Copy 由于结构化并发是孵化器功能

    31700编辑于 2025-04-05
  • 来自专栏悠扬前奏的博客

    Java并发-10.等待通知

    等待/通知的方法定义在所有对象的超类java.lang.Object上。 方法 描述 notify() 通知一个在对象上等待的线程,使其从wait()方法返回,返回的前提是线程获取了对象的锁 notifyAll() 通知所有在该对象上等待的线程 wait() 调用该方法的线程进入WAITING状态,只有等待另外线程的通知或被中断才会返回,调用wait()方法会释放对象的锁 wait(long) 超时等待一段时间,毫秒为单位 wait(long, int) 对超时时间的细粒度控制 ,可以达到纳秒 示例代码:

    96130发布于 2019-05-28
  • 来自专栏深度学习与python

    Java 近期新闻:结构化并发、Java 满 27 岁、Micronaut 3.5.0

    Michael Redlich 译者 | 平川 策划 | 丁晓昀 本期 Java 近期新闻综述内容主要涉及 OpenJDK、JDK 19、虚拟线程、Java 满 27 岁、Jakarta EE 10 JEP 428(结构化并发第一轮孵化)从 JDK 19 的候选状态提升到 Proposed to Target 状态。 Jakarta EE 在通往 Jakarta EE 10 的道路上,Eclipse 基金会 Jakarta EE 开发大使 Ivar Grimstad 在他的每周博客 Hashtag Jakarta EE 中宣布,除了 Jakarta Security 3.0 之外,所有针对 Jakarta EE 10 规范的发布审查现在都已经完成,而前者应该也很快就可以完成。

    1.1K20编辑于 2023-03-29
  • 来自专栏IT技术精选文摘

    聊聊并发编程的 10 个坑

    前言 对于从事后端开发的同学来说,并发编程肯定再熟悉不过了。 说实话,在java中并发编程是一大难点,至少我是这么认为的。不光理解起来比较费劲,使用起来更容易踩坑。 不信,让继续往下面看。 今天重点跟大家一起聊聊并发编程的10个坑,希望对你有帮助。 1. SimpleDateFormat线程不安全

    19920编辑于 2022-04-08
  • 来自专栏WindCoder

    并发学习笔记10-happens-before

    并发学习系列以阅读《Java并发编程的艺术》一书的笔记为蓝本,汇集一些阅读过程中找到的解惑资料而成。这是一个边看边写的系列,有兴趣的也可以先自行购买此书学习。 本文首发:[windCoder]( https://windcoder.com/bingfaxuexibiji10-happens-before ‎ "windCoder") JMM把happens-before

    37820发布于 2020-01-22
  • 来自专栏苏三说技术

    聊聊并发编程的10个坑

    前言 对于从事后端开发的同学来说,并发编程肯定再熟悉不过了。 说实话,在java中并发编程是一大难点,至少我是这么认为的。不光理解起来比较费劲,使用起来更容易踩坑。 不信,让继续往下面看。 今天重点跟大家一起聊聊并发编程的10个坑,希望对你有帮助。 1. 在这些低并发场景下,很难出现OOM问题,所以我们需要根据实际业务场景选择。 8. @Async注解的陷阱 之前在java并发编程中实现异步功能,一般是需要使用线程或者线程池。 自旋锁浪费cpu资源 在并发编程中,自旋锁想必大家都已经耳熟能详了。 10. ThreadLocal用完没清空 在java中保证线程安全的技术有很多,可以使用synchroized、Lock等关键字给代码块加锁。

    60430编辑于 2022-08-25
  • 来自专栏挖掘大数据

    结构化数据分析的10个步骤

    企业必须对结构化和非结构化数据有所了解,才能更好地为业务发展做出正确决策。本文将详细介绍企业分析非结构化数据的10个步骤: 1.确定一个数据源 了解有利于小型企业的数据来源非常重要。 2.管理非结构化数据搜索工具 收集到的结构化或非结构化的数据在使用上会有所不同。查找和收集数据只是一个步骤,构建非结构化数据搜索并使其有用是另一回事。 因此,企业在拥有太多非结构化数据之前,先找到一个良好的业务管理工具。 3.消除无用的数据 在收集数据并实现结构化之后,消除无用的数据是第三个步骤。 9.记录统计 通过上述所有步骤将非结构化数据变成结构化数据后,就可以创建统计信息了。对数据进行分类和分段以便于使用和学习,并为将来的使用创造一个良好的流程。 10.分析数据 这是索引非结构化数据的最后一步。在所有的原始数据实现结构化之后,就应该分析和做出与业务相关且有益的决策。索引还可帮助小型企业为将来的使用制定一致的模式。

    3.1K00发布于 2017-12-27
  • 来自专栏JAVA并发编程

    JAVA并发编程系列(10)Condition条件队列-并发协作者

    最开始我们学JAVA编程,都是从synchronized开始,线程并发协调,常用的就是对象的wait(),nofity()方法。 今天就分享这么多,目前已分享synchronized、volatile、AQS、CAS、ReentrantLock、Semaphore、CountDownLatch、CyclicBarrier、Condition,并发编程里的基础中的基础已经分享完了 下次我们分享线程池、并发容器、ThreadLocal、Future、FutureTask.

    35420编辑于 2024-09-23
  • 来自专栏JavaEdge

    掌握JDK21全新结构化并发编程,轻松提升开发效率!

    1 概要通过引入结构化并发编程的API,简化并发编程。结构化并发将在不同线程中运行的相关任务组视为单个工作单元,从而简化错误处理和取消操作,提高可靠性,并增强可观察性。这是一个预览版的API。 4 非目标不替换JUC包中的任何并发构造,如ExecutorService和Future。不定义Java平台的最终结构化并发API。其他结构化并发构造可以由第三方库定义,或在未来的JDK版本中定义。 这种表示将实现错误传播、取消以及对并发程序的有意义的观察。7 结构化并发结构化并发是一种并发编程方法,它保持了任务和子任务之间的自然关系,从而实现了更具可读性、可维护性和可靠性的并发代码。" 结构化并发源于一个简单的原则:如果一个任务分解为并发的子任务,那么所有这些子任务都会返回到同一个地方,即任务的代码块。在结构化并发中,子任务代表任务工作。任务等待子任务的结果并监视它们的失败情况。 这符合结构化并发的精神,即整个作用域被视为一个单元。

    1.6K31编辑于 2023-08-22
  • 来自专栏JavaEdge

    再见了Future,图解JDK21虚拟线程的结构化并发

    我们将介绍结构化并发的概念,然后讨论Java 21中一组预览类——它使将任务拆分为子任务、收集结果并对其进行操作变得非常容易,而且不会不小心留下任何挂起的任务。 这就引出结构化并发的基本思想。 4 结构化并发 想象,从方法内部向ExecutorService提交的任务,然后方法退出。 该问题的图解: 结构化并发基本思想是从一个块(方法或块)内启动的所有任务应在该块结束前终止。即: 代码的结构边界(块) 和该块内提交的任务的运行时边界 重合。 ExecutorService的try-with-resources块是对结构化并发的一次良好尝试,其中从块内提交的所有任务在块退出时完成。但它还不够,因为它可能导致父线程等待时间超过必要时间。 它试图提供比Executor Service的try-with-resources块更干净的结构化并发模型。

    3.2K10编辑于 2023-12-11
  • 来自专栏海天一树

    结构化、半结构化和非结构化数据

    一、结构化数据 结构化的数据是指可以使用关系型数据库表示和存储,表现为二维形式的数据。一般特点是:数据以行为单位,一行数据表示一个实体的信息,每一行数据的属性是相同的。 二、半结构化数据 半结构化数据是结构化数据的一种形式,它并不符合关系型数据库或其他数据表的形式关联起来的数据模型结构,但包含相关标记,用来分隔语义元素以及对记录和字段进行分层。 所以,半结构化数据的扩展性是很好的。 三、非结构化数据 非结构化数据是数据结构不规则或不完整,没有预定义的数据模型,不方便用数据库二维逻辑表来表现的数据。 非结构化数据其格式非常多样,标准也是多样性的,而且在技术上非结构化信息比结构化信息更难标准化和理解。 非结构化数据,包括视频、音频、图片、图像、文档、文本等形式。

    24.3K44发布于 2018-10-08
领券