首页 Java Java基础 一起和Netty学习Java锁的使用

一起和Netty学习Java锁的使用

Jan 04, 2021 am 10:04 AM
netty

java基础教程栏目介绍如何和Netty学习Java锁

一起和Netty学习Java锁的使用

推荐(免费):java基础教程

1 锁的对象和范围

  • 缩小粒度

2 锁的对象本身大小

  • 减少空间占用

    Atomic long V.S long
    前者是个对象,包含对象头(object header)以保存hashcode、lock 等信息,64 位系统下占16字节,64位系统下:
  • volatile long= 8 bytes
  • AtomicLong = 8 bytes (volatile long) + 16bytes (对象头) + 8 bytes (引用) = 32 bytes
    至少节约24字节!

所以 Atomic* objects =》 Volatile primary type + Static Atomic*FieldUpdater

3 锁的速度

提高并发性

LongCounter

记录内存分配字节数等功能用到的。
高并发下: java.util.concurrent.atomic.AtomicLong => java.util.concurrent.atomic.LongAdder

结论:及时衡量、使用JDK最新的功能

根据不同情况,选择不同的并发包实现

JDK< 1.8考虑ConcurrentHashMapV8 ( ConcurrentHashMap在jDK8中的版本)

4 不同场景选择不同的并发类

因需而变

  • 关闭和等待关闭事件执行器( Event Executor):
    Object.wait/ notify =》 CountDownLatch

  • Nio Event loop中负责存储task的Queue
    Jdk’s LinkedBlockingQueue (MPMC,多生产者多消费者) -> jctools’ MPSC
    io.netty.util.internal.PlatformDependent.Mpsc#newMpscQueue(int):

    5 锁的价值

    能不用则不用
    Netty应用场景下:局部串行+整体并行>- -个队列+多个线程模式:
    降低用户开发难度、逻辑简单、提升处理性能
    避免锁带来的上下文切换和并发保护等额外开销

    避免用锁:用ThreadLocal来避免资源争用,例如Netty轻量级的线程池实现

    以上是一起和Netty学习Java锁的使用的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Java API 开发中使用 Netty4 进行 TCP 通信 Java API 开发中使用 Netty4 进行 TCP 通信 Jun 17, 2023 pm 11:18 PM

TCP是计算机网络通信协议的一种,是一种面向连接的传输协议。在Java应用开发中,TCP通信被广泛应用于各种场景,比如客户端和服务器之间的数据传输、音视频实时传输等等。Netty4是一个高性能、高可扩展性、高性能的网络编程框架,能够优化服务器和客户端之间的数据交换过程,使其更加高效可靠。使用Netty4进行TCP通信的具体实现步骤如下:引入

Java开发:如何使用Netty进行高性能网络编程 Java开发:如何使用Netty进行高性能网络编程 Sep 20, 2023 pm 02:09 PM

Java开发:如何使用Netty进行高性能网络编程摘要:Netty是一个高性能、异步事件驱动的网络编程框架,能够简化网络应用程序的开发过程。本文将介绍Netty的主要特点以及如何使用Netty进行高性能网络编程。同时,我们还会提供一些具体的Java代码示例,帮助读者更好地理解和应用Netty。一、Netty简介Netty是一个基于JavaNIO的网络编程框

PHP实现开源Netty框架 PHP实现开源Netty框架 Jun 18, 2023 pm 07:03 PM

随着互联网技术的不断发展,网络程序设计变得越来越重要。在这个领域中,Netty是一个十分知名的框架。它是一个高性能、异步事件驱动的网络应用程序框架,被广泛用于开发各种高并发的网络应用程序。Netty是一个Java框架,它的产生推动了Java网络编程的发展。然而,随着PHP的广泛使用,PHP开发者也在寻找能够胜任高并发网络编程的框架。因此,本文介绍了如何利用P

springboot整合netty框架的方式有哪些 springboot整合netty框架的方式有哪些 May 10, 2023 pm 09:55 PM

netty作为一个高性能的io框架,是非好用的一个技术框架,Netty是一个基于NIO的客户、服务器端编程框架,使用Netty可以确保你快速和简单的开发出一个网络应用,例如实现了某种协议的客户、服务端应用。Netty相当于简化和流线化了网络应用的编程开发过程,例如:基于TCP和UDP的socket服务开发。“快速”和“简单”并不用产生维护性或性能上的问题。Netty是一个吸收了多种协议(包括FTP、SMTP、HTTP等各种二进制文本协议)的实现经验,并经过相当精心设计的项目。最终,Netty成功

如何使用Java开发一个基于Netty的高性能网络应用 如何使用Java开发一个基于Netty的高性能网络应用 Sep 20, 2023 pm 12:21 PM

如何使用Java开发一个基于Netty的高性能网络应用Netty是一种基于JavaNIO技术的网络编程框架,被广泛应用于高性能的网络应用开发。在本文中,我们将探讨如何使用Java和Netty来开发一个基于Netty的高性能网络应用。我们将介绍Netty的基本概念和特性,并提供一些代码示例以帮助你更好地理解和使用Netty。一、Netty的基本概念和特性Ne

Java后端开发:使用Netty构建高并发API服务器 Java后端开发:使用Netty构建高并发API服务器 Jun 17, 2023 am 10:23 AM

随着互联网的不断发展和应用领域的不断扩展,高并发成为了网络应用开发中必须考虑的问题,而Java作为一种广泛应用于企业级应用开发的语言,其在高并发应用场景下的表现备受关注。Netty是一款高性能、异步事件驱动的网络应用框架,近年来在Java后端开发领域享有广泛的应用。本文将介绍Netty的基本概念和使用方法,并以搭建一个高并发的API服务器为例,展示Netty

Java API 开发中使用 Netty 进行 TCP 通信 Java API 开发中使用 Netty 进行 TCP 通信 Jun 18, 2023 pm 11:34 PM

JavaAPI开发中使用Netty进行TCP通信在现代软件开发中,网络通信已成为必不可少的一部分。Netty是一种Java框架,用于在高性能网络应用中有效地进行快速开发。它提供了一组易于使用的API,封装了JavaNIO和其他网络库。在JavaAPI开发中,Netty的优越性可以体现在如下几个方面:高性能Netty的应用程

Java IO模型和Netty框架的概述 Java IO模型和Netty框架的概述 Apr 22, 2023 pm 02:34 PM

什么是Netty异步,基于事件驱动的网络应用框架,用以快速开发高性能,高可靠的网络IO程序主要针对在TCP协议下,面向Clients端的高并发应用本质是一个NIO框架,适用于服务器通讯等场景异步:发送请求无需等待响应,程式接着往下走。事件驱动:一个连接事件或者断开事件,或者读事件或者写事件,发生后的后续处理。Netty典型应用:高性能rpc框架用来远程服务(过程)调用,比如Dubbo。游戏行业,页面数据交互。大数据领域如Hadoop高性能通讯和序列化组件(AVRO)。IO模型简单理解就是用什么通

See all articles