当前位置:首页 > 科技  > 软件

JCStress—验证你的并发程序是否正确

来源: 责编: 时间:2023-10-26 17:12:02 454观看
导读背景JCStress(Java Concurrency Stress Tests)是一个用于测试和验证Java并发程序正确性的工具。它是OpenJDK项目的一部分,旨在帮助开发人员发现并发程序中的竞态条件、死锁、内存可见性等问题。JCStress提供了一组注解和

mIC28资讯网——每日最新资讯28at.com

背景

JCStress(Java Concurrency Stress Tests)是一个用于测试和验证Java并发程序正确性的工具。它是OpenJDK项目的一部分,旨在帮助开发人员发现并发程序中的竞态条件、死锁、内存可见性等问题。mIC28资讯网——每日最新资讯28at.com

JCStress提供了一组注解和API,使得编写并发测试变得简单和方便。使用JCStress,您可以定义和运行各种类型的并发测试,包括多线程竞争测试、内存可见性测试、有序性测试等。JCStress会自动执行大量的并发测试用例,并生成详细的测试报告,以帮助您分析和理解并发程序的行为。mIC28资讯网——每日最新资讯28at.com

JCStress的主要特点包括:mIC28资讯网——每日最新资讯28at.com

  • 并发测试:JCStress支持编写各种类型的并发测试,包括竞争条件测试、死锁测试、内存可见性测试等。
  • 自动化测试:JCStress会自动执行大量的并发测试用例,并尝试发现潜在的并发问题。
  • 测试报告:JCStress生成详细的测试报告,包括测试结果、执行时间、线程状态等信息,以帮助您分析并发程序的行为。
  • 高度可配置:JCStress提供了丰富的配置选项,如线程数、迭代次数、测试模式等,以满足不同类型的并发测试需求。

JCStress使用

使用JCStress编写和运行并发测试的一般步骤包括:mIC28资讯网——每日最新资讯28at.com

  • 在测试类或测试方法上使用JCStress提供的注解,如@JCStressTest、@Actor、@Outcome等,来定义并发测试。
  • 使用JCStress提供的命令行工具或API来运行并发测试,并指定相关的选项和参数。
  • 分析和解释JCStress生成的测试报告,以发现并发问题并进行修复。

JCStress使用示例

测试用例1:mIC28资讯网——每日最新资讯28at.com

/*    This is our first concurrency test. It is deliberately simplistic to show    testing approaches, introduce JCStress APIs, etc.    Suppose we want to see if the field increment is atomic. We can make test    with two actors, both actors incrementing the field and recording what    value they observed into the result object. As JCStress runs, it will    invoke these methods on the objects holding the field once per each actor    and instance, and record what results are coming from there.    Done enough times, we will get the history of observed results, and that    would tell us something about the concurrent behavior.    How to run this test:       $ java -jar jcstress-samples/target/jcstress.jar -t API_01_Simple       ...        .......... [OK] org.openjdk.jcstress.samples.api.API_01_Simple          Scheduling class:            actor1: package group 0, core group 0            actor2: package group 0, core group 0          CPU allocation:            actor1: CPU #3, package #0, core #3            actor2: CPU #35, package #0, core #3          Compilation: split            actor1: C2            actor2: C2          JVM args: []          RESULT      SAMPLES    FREQ       EXPECT  DESCRIPTION            1, 1   46,946,789   10.1%  Interesting  Both actors came up with the same value: atomicity failure.            1, 2  110,240,149   23.8%   Acceptable  actor1 incremented, then actor2.            2, 1  306,529,420   66.1%   Acceptable  actor2 incremented, then actor1. */// Mark the class as JCStress test.@JCStressTest// These are the test outcomes.@Outcome(id = "1, 1", expect = ACCEPTABLE_INTERESTING, desc = "Both actors came up with the same value: atomicity failure.")@Outcome(id = "1, 2", expect = ACCEPTABLE, desc = "actor1 incremented, then actor2.")@Outcome(id = "2, 1", expect = ACCEPTABLE, desc = "actor2 incremented, then actor1.")// This is a state object@Statepublic class API_01_Simple {    int v;    @Actor    public void actor1(II_Result r) {        r.r1 = ++v; // record result from actor1 to field r1    }    @Actor    public void actor2(II_Result r) {        r.r2 = ++v; // record result from actor2 to field r2    }}

测试用例2:mIC28资讯网——每日最新资讯28at.com

@JCStressTest@Outcome(id = {"1, 2", "2, 1"}, expect = ACCEPTABLE, desc = "Mutex works")@Outcome(id = "1, 1",           expect = FORBIDDEN,  desc = "Mutex failure")@Statepublic class Mutex_06_Semaphore {    /*        How to run this test:            $ java -jar jcstress-samples/target/jcstress.jar -t Mutex_06_Semaphore    */    /*      ----------------------------------------------------------------------------------------------------------        Single-permit Semaphore can be used as a crude mutex too. Of course, this primitive        is much more flexible, it can admit a few threads at once with more permits.        On x86_64, AArch64, PPC64:          RESULT      SAMPLES     FREQ      EXPECT  DESCRIPTION            1, 1            0    0.00%   Forbidden  Mutex failure            1, 2  254,394,919   50.23%  Acceptable  Mutex works            2, 1  252,081,625   49.77%  Acceptable  Mutex works     */    private final Semaphore semaphore = new Semaphore(1);    private int v;    @Actor    public void actor1(II_Result r) {        try {            semaphore.acquire();            // critical section            r.r1 = ++v;            semaphore.release();        } catch (InterruptedException e) {            throw new IllegalStateException(e);        }    }    @Actor    public void actor2(II_Result r) {        try {            semaphore.acquire();            // critical section            r.r2 = ++v;            semaphore.release();        } catch (InterruptedException e) {            throw new IllegalStateException(e);        }    }}

JCStress总结

JCStress是一个强大的工具,可以帮助开发人员测试和验证Java并发程序的正确性。它广泛应用于Java开发社区,并被认为是Java并发测试领域的事实标准。使用JCStress可以提高并发程序的质量和可靠性,减少并发问题的出现。mIC28资讯网——每日最新资讯28at.com

参考资料:mIC28资讯网——每日最新资讯28at.com

【1】https://github.com/openjdk/jcstress/tree/master/jcstress-samples/src/main/java/org/openjdk/jcstress/samples。mIC28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-15222-0.htmlJCStress—验证你的并发程序是否正确

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 你是否知道如何使用Python PyQt6事件处理器?

下一篇: JavaScript中闭包的四个有用技巧

标签:
  • 热门焦点
  • 掘力计划第 20 期:Flutter 混合开发的混乱之治

    在掘力计划系列活动第20场,《Flutter 开发实战详解》作者,掘金优秀作者,Github GSY 系列目负责人恋猫的小郭分享了Flutter 混合开发的混乱之治。Flutter 基于自研的 Skia 引擎
  • 使用Webdriver-manager解决浏览器与驱动不匹配所带来自动化无法执行的问题

    1、前言在我们使用 Selenium 进行 UI 自动化测试时,常常会因为浏览器驱动与浏览器版本不匹配,而导致自动化测试无法执行,需要手动去下载对应的驱动版本,并替换原有的驱动,可能还
  • 从零到英雄:高并发与性能优化的神奇之旅

    作者 | 波哥审校 | 重楼作为公司的架构师或者程序员,你是否曾经为公司的系统在面对高并发和性能瓶颈时感到手足无措或者焦头烂额呢?笔者在出道那会为此是吃尽了苦头的,不过也得
  • JVM优化:实战OutOfMemoryError异常

    一、Java堆溢出堆内存中主要存放对象、数组等,只要不断地创建这些对象,并且保证 GC Roots 到对象之间有可达路径来避免垃 圾收集回收机制清除这些对象,当这些对象所占空间超过
  • 本地生活这块肥肉,拼多多也想吃一口

    出品/壹览商业 作者/李彦编辑/木鱼拼多多也看上本地生活这块蛋糕了。近期,拼多多在App首页“充值中心”入口上线了本机生活界面。壹览商业发现,该界面目前主要
  • “又被陈思诚骗了”

    作者|张思齐 出品|众面(ID:ZhongMian_ZM)如今的国产悬疑电影,成了陈思诚的天下。最近大爆电影《消失的她》票房突破30亿断层夺魁暑期档,陈思诚再度风头无两。你可以说陈思诚的
  • 8月见!小米MIX Fold 3获得3C认证:支持67W快充

    这段时间以来,包括三星、一加、荣耀等等有不少品牌旗下的最新折叠屏旗舰都得到了不少爆料,而小米新一代折叠屏旗舰——小米MIX Fold 3此前也屡屡被传
  • 三星获批量产iPhone 15全系屏幕:苹果史上最惊艳直屏

    按照惯例,苹果将继续在今年9月举办一年一度的秋季新品发布会,有传言称发布会将于9月12日举行,届时全新的iPhone 15系列将正式与大家见面,不出意外的话
  • 朋友圈可以修改可见范围了 苹果用户可率先体验

    近日,iOS用户迎来微信8.0.27正式版更新,除了可更换二维码背景外,还新增了多项实用功能。在新版微信中,朋友圈终于可以修改可见范围,简单来说就是已发布的朋友圈
Top