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

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

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

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

背景

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

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

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

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

JCStress使用

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

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

JCStress使用示例

测试用例1:K9328资讯网——每日最新资讯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:K9328资讯网——每日最新资讯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可以提高并发程序的质量和可靠性,减少并发问题的出现。K9328资讯网——每日最新资讯28at.com

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

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

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

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

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

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

标签:
  • 热门焦点
  • vivo TWS Air开箱体验:真轻 臻好听

    在vivo S15系列新机的发布会上,vivo的最新款真无线蓝牙耳机vivo TWS Air也一同发布,本次就这款耳机新品给大家带来一个简单的分享。外包装盒上,vivo TWS Air保持了vivo自家产
  • 5月安卓手机好评榜:魅族20 Pro夺冠

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年5月1日至5月31日,仅限国内市场。第一名:魅族20 Pro好评率:97.50%不得不感慨魅族老品牌还
  • 服务存储设计模式:Cache-Aside模式

    Cache-Aside模式一种常用的缓存方式,通常是把数据从主存储加载到KV缓存中,加速后续的访问。在存在重复度的场景,Cache-Aside可以提升服务性能,降低底层存储的压力,缺点是缓存和底
  • SpringBoot中使用Cache提升接口性能详解

    环境:springboot2.3.12.RELEASE + JSR107 + Ehcache + JPASpring 框架从 3.1 开始,对 Spring 应用程序提供了透明式添加缓存的支持。和事务支持一样,抽象缓存允许一致地使用各
  • 分布式系统中的CAP理论,面试必问,你理解了嘛?

    对于刚刚接触分布式系统的小伙伴们来说,一提起分布式系统,就感觉高大上,深不可测。而且看了很多书和视频还是一脸懵逼。这篇文章主要使用大白话的方式,带你理解一下分布式系统
  • 微信语音大揭秘:为什么禁止转发?

    大家好,我是你们的小米。今天,我要和大家聊一个有趣的话题:为什么微信语音不可以转发?这是一个我们经常在日常使用中遇到的问题,也是一个让很多人好奇的问题。让我们一起来揭开这
  • 阿里大调整

    来源:产品刘有媒体报道称,近期淘宝天猫集团启动了近年来最大的人力制度改革,涉及员工绩效、层级体系等多个核心事项,目前已形成一个初步的“征求意见版”:1、取消P序列
  • 质感不错!OPPO K11渲染图曝光:旗舰IMX890传感器首次下放

    一直以来,OPPO K系列机型都保持着较为均衡的产品体验,历来都是2K价位的明星机型,去年推出的OPPO K10和OPPO K10 Pro两款机型凭借各自的出色配置,堪称有
  • Counterpoint :OPPO双旗舰战略全面落地 高端产品销量增长22%

    2023年6月30日,全球行业分析机构Counterpoint Research发布的《中国智能手机高端市场白皮书》显示,中国智能手机品牌正在寻求高质量发展,中国高端智能
Top