首页 > 编程语言 >Java开发手册中-锁并发-同步调用应该去考量锁的性能损耗-加锁与不加锁性能对比

Java开发手册中-锁并发-同步调用应该去考量锁的性能损耗-加锁与不加锁性能对比

时间:2024-07-17 14:40:48浏览次数:14  
标签:加锁 Java 性能 jmh 测试 org import

场景

Java中使用JMH(Java Microbenchmark Harness 微基准测试框架)进行性能测试和优化:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/131723751

参考以上性能测试工具的使用。

Java中数据同步-synchronized关键字与Mointor(jconsole)的使用:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/126743812

参考以上synchronized关键字的使用。

《Java开发手册》中关于锁并发中有要求:

【强制】高并发时,同步调用应该去考量锁的性能损耗。能用无锁数据结构,就不要用锁;

能锁区块,就不要锁整个方法体;能用对象锁,就不要用类锁。

说明:尽可能使加锁的代码块工作量尽可能的小,避免在锁代码块中调用 RPC 方法。

 

注:

博客:
https://blog.csdn.net/badao_liumang_qizhi

实现

接下来我们来测试⼀下,在线程安全的情况下(单线程),无锁和有锁的性能差距有多⼤

测试代码如下

import org.openjdk.jmh.annotations.*;
import org.openjdk.jmh.runner.Runner;
import org.openjdk.jmh.runner.RunnerException;
import org.openjdk.jmh.runner.options.Options;
import org.openjdk.jmh.runner.options.OptionsBuilder;
import java.util.concurrent.TimeUnit;

//测试完成时间
@BenchmarkMode(Mode.AverageTime)
//设置统计结果的时间单位
@OutputTimeUnit(TimeUnit.NANOSECONDS)
@Warmup(iterations = 2,time = 1,timeUnit = TimeUnit.SECONDS)
//测试次数和时间,参数同上
@Measurement(iterations = 5,time = 1,timeUnit = TimeUnit.SECONDS)
//fork一个线程,进行 fork 的次数,可用于类或者方法上。如果 fork 数是 2 的话,则 JMH 会 fork 出两个进程来进行测试。
@Fork(1)
//通过 State 可以指定一个对象的作用范围,JMH 根据 scope 来进行实例化和共享操作。@State 可以被继承使用,
//Scope.Thread:默认的 State,每个测试线程分配一个实例
@State(Scope.Thread)
public class SynchronizedTest {

    public static void main(String[] args) throws RunnerException {
        //启动基准测试
        Options options = new OptionsBuilder()
                .include(SynchronizedTest.class.getSimpleName())//要导入的测试类
                .build();
        new Runner(options).run();//执行测试
    }

    //测试加锁
    @Benchmark
    @GroupThreads(1)//标记单线程运行
    public void synchronizedTest(){
        int count = 0;
        synchronized (this){
            for(int i = 0;i<10000;i++){
                count++;
            }
        }
    }

    //测试不加锁
    @Benchmark
    @GroupThreads(1)//标记单线程运行
    public void noLockTest(){
        int count = 0;
        for(int i = 0;i<10000;i++){
            count++;
        }
    }
}

测试结果

//Benchmark                          Mode  Cnt   Score   Error  Units
//SynchronizedTest.noLockTest        avgt    5   0.257 ± 0.029  ns/op
//SynchronizedTest.synchronizedTest  avgt    5  18.188 ± 3.749  ns/op

从上述结果可以看出,在单线程条件下,无锁和有锁的性能差距大概是 9倍多,

因此能不⽤锁就尽量不要⽤锁(前提是保证结果的正确性),如果要⽤锁就要尽量缩⼩锁的包含范围。

标签:加锁,Java,性能,jmh,测试,org,import
From: https://www.cnblogs.com/badaoliumangqizhi/p/18307332

相关文章

  • Java开发手册中为什么要求集合转数组toArray时禁止使用无参方法,而使用传参长度为0的空
    场景Java中使用JMH(JavaMicrobenchmarkHarness微基准测试框架)进行性能测试和优化:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/131723751参考以上性能测试工具的使用。阿里巴巴《java开发手册》泰山版关于集合转数组时规范声明:【强制】使⽤集合转数组的⽅......
  • Java中的RESTful API设计与实现
    Java中的RESTfulAPI设计与实现大家好,我是微赚淘客系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!一、引言在现代Web开发中,RESTfulAPI已经成为数据传输的标准方式。REST(RepresentationalStateTransfer)是一种基于资源的架构风格,广泛应用于互联网服务中。本文将详细介绍......
  • Java中的分布式文件系统设计与实现
    Java中的分布式文件系统设计与实现大家好,我是微赚淘客系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!一、引言分布式文件系统是支持大规模数据存储和访问的关键基础设施之一。本文将探讨在Java语言环境中设计和实现分布式文件系统的关键技术和策略。二、分布式文件系统的......
  • Java中的响应式编程与Reactor框架使用详解
    Java中的响应式编程与Reactor框架使用详解大家好,我是微赚淘客系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!一、引言响应式编程是一种面向数据流和变化传播的编程范式,它适用于处理异步数据流和事件驱动的场景。Reactor框架是在Java中实现响应式编程的强大工具,本文将深入......
  • java八股复习指南-多线程篇
    多线程线程的实现在Java中,实现多线程的主要有以下四种继承Thread类,重写run()方法;实现Runnable接口,实现run()方法,并将Runnable实现类的实例作为Thread构造函数的参数target;实现Callable接口,实现call()方法,然后通过FutureTask包装器来创建Thread线程;......
  • 使用Java和JHipster快速构建现代化的Web应用
    使用Java和JHipster快速构建现代化的Web应用大家好,我是微赚淘客系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!引言在当今快节奏的软件开发环境中,快速构建现代化的Web应用是开发团队面临的重要挑战之一。本文将介绍如何利用Java和JHipster工具来快速搭建一个现代化的Web应......
  • 华为OD机试D卷 --找座位--24年OD统一考试(Java & JS & Python & C & C++)
    文章目录题目描述输入描述输出描述用例题目解析java源码python源码javascript源码c源码c++源码题目描述在一个大型体育场内举办了一场大型活动,由于疫情防控的需要,要求每位观众的必须间隔至少一个空位才允许落座。现在给出一排观众座位分布图,座位中存......
  • 华为OD机试D卷 --密码输入检测--24年OD统一考试(Java & JS & Python & C & C++)
    文章目录题目描述输入描述输出描述用例题目解析java源码python源码javascript源码c源码c++源码题目描述给定用户密码输入流input,输入流中字符‘<’表示退格,可以清除前一个输入的字符,请你编写程序,输出最终得到的密码字符,并判断密码是否满足如下的密......
  • MViT:性能杠杠的多尺度ViT | ICCV 2021
    论文提出了多尺度视觉Transformer模型MViT,将多尺度层级特征的基本概念与Transformer模型联系起来,在逐层扩展特征复杂度同时降低特征的分辨率。在视频识别和图像分类的任务中,MViT均优于单尺度的ViT。来源:晓飞的算法工程笔记公众号论文:MultiscaleVisionTransformers论文......
  • 如何在Java中实现事件驱动的微服务架构
    如何在Java中实现事件驱动的微服务架构大家好,我是微赚淘客系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!一、引言事件驱动架构(EDA)是一种基于事件进行通信和操作的架构模式,适用于高度分布式和松耦合的系统。微服务架构结合事件驱动可以提升系统的可扩展性和响应性。本文将......