哪个内存更快?Heap或ByteBuffer或Direct?

Java正在成为新的C / C ++,它被广泛用于开发高性能系统。 对像我这样的数百万Java开发人员来说非常好!
在这个博客中,我将分享我可以用Java完成的不同类型的内存分配实验以及您从中获得的好处。

Java中的内存分配

Java提供哪种类型的内存分配支持:

–堆内存

我不必解释这一点,所有Java应用程序都以此开头。 使用“ new”关键字分配的所有对象都在“堆内存”下

–非直接字节缓冲区

它是字节数组的包装,只是堆内存的味道。
ByteBuffer.allocate()可用于创建这种类型的对象,如果您要处理字节而不是对象,则非常有用。

–直接字节缓冲区

这是Java自JDK 1.4起添加的真实内容。
基于Java Doc的Direct ByteBuffer的描述

“直接字节缓冲区可以通过调用此类的allocateDirect工厂方法来创建。 这种方法返回的缓冲区通常比非直接缓冲区具有更高的分配和释放成本。 直接缓冲区的内容可能驻留在普通垃圾回收堆的外部,因此它们对应用程序内存占用的影响可能并不明显。 因此,建议直接缓冲区主要分配给大型,寿命长的缓冲区,这些缓冲区要受基础系统的本机I / O操作的约束。 通常,最好仅在直接缓冲区产生可观的程序性能提升时才分配它们。”

关于直接缓冲区要注意的重要事项是

  • 它在JVM之外
  • 不受垃圾收集器影响。

如果您关心性能,这些都是非常重要的事情。
MemoryMapped文件也具有Direct字节缓冲区的风格,我在以下博客中与我分享了一些发现:

  • arraylist使用内存映射文件
  • Java记忆文件的功能

堆或直接内存

这与Direct ByteBuffer几乎相同,但是几乎没有什么不同,它可以由unsafe.allocateMemory分配,因为它是直接内存,因此不会产生GC开销。 这种类型的内存必须手动释放。

从理论上讲,不允许Java程序员进行这种分配,我认为原因可能是

  • 操作这种类型的内存很复杂,因为您只处理字节而不是对象
  • C / C ++社区不会喜欢它

让我们深入研究内存分配

对于内存分配测试,我将使用13字节的消息,并将其分解为

  • int – 4个字节
  • 长– 8字节
  • 字节– 1字节

我只会测试写入/读取性能,而不会测试内存消耗/分配速度。

写性能

分配-写TP

X轴 –没有读数

Y轴 -运算/秒(百万)

使用4种分配类型写入500万个13字节对象。

  1. 在这种情况下,最好使用Direct ByteBuffer和Off Heap,吞吐量接近
  2. 3.5亿/秒
  3. 普通的ByteBuffer非常慢,TP仅为8500万/秒
  4. Direct / Off堆比堆快1.5倍

我对5000万个对象进行了相同的测试,以检查其缩放比例,以下是相同的图形。
分配-写TP 50
X轴 –没有读数 Y轴 -运算/秒(百万) 数字几乎等于500万。

阅读表现

让我们看一下阅读性能
分配-阅读TP 5
X轴 –没有读数 Y轴 -运算/秒(百万) 这个数字很有趣,OFF堆正在为12,000 Mills / Sec快速吞吐。 HEAP读取仅接近一次,比OFF Heap慢6倍左右。 看一下Direct ByteBuffer,它的传输速度仅为4亿/秒,不知道为什么会这样。

让我们看看5000万个对象的数量
分配-阅读TP 50
X轴 –没有读数 Y轴 -运算/秒(百万) 没有太大的不同。

结论

通过Unsafe进行的堆外活动以330/11200百万/秒的速度快速燃烧
所有其他类型的分配的性能对读取或写入均有利,而对这两种分配均无好处。
关于ByteBuffer的特别说明,这是可悲的,我确定看到这样的数字后您将不会使用它。 DirectBytebuffer的读取速度很慢,我不确定为什么它这么慢。

因此,如果内存读/写正在成为系统的瓶颈,那么肯定要走“堆外”的方式,请记住这是高速公路,因此请谨慎驾驶。

代码可用@ git hub

参考: 哪个内存更快Heap或ByteBuffer或Direct? 来自我们的JCG合作伙伴 Ashkrit Sharma,网址为Are you ready博客。

翻译自: https://www.javacodegeeks.com/2013/08/which-memory-is-faster-heap-or-bytebuffer-or-direct.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/367123.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java没有打印mysql日志_0216 aop和打印数据库执行日志

需求maven依赖p6spyp6spy3.8.7com.google.guavaguava28.2-jreorg.springframework.bootspring-boot-starter-data-jpaorg.springframework.bootspring-boot-starter-webmysqlmysql-connector-javaruntimeorg.projectlomboklomboktrue打印sql配置要点:驱动配置 appli…

php数组基础

php中,数组的下标可以是整数,或字符串。 php中,数组的元素顺序不是由下标决定,而是由其“加入”的顺序决定。 定义: $arr1 array(元素1,元素2,。。。。。 ); array(1, 5, 1.1, “abc”, tr…

1.格式化输入输出

1.格式化输入input() input()函数,通常只能返回一个数据类型,那么怎么可以进行多个变量的复制呢?看下面这段代码。 1 str1, str2 eval(input("请输入两个字符串:")) 2 print(str1, str2) 3 4 num1, num2 eval(input(…

canvas像素点操作 —— 视频绿幕抠图

原文地址 主要内容 上篇文章学习了canvas像素点的获取 —— 传送门, 今天学一下canvas像素点操作。 一个方法:putImageData putImageData 用法: context.putImageData(imgData, x, y, dX, dY, dWidth, dHeight);参数描述imgData规定要放…

Java中的迭代器设计模式–示例教程

迭代器模式是一种行为模式,用于提供遍历一组对象的标准方式。 Iterator模式在Java Collection Framework中得到了广泛使用,其中Iterator接口提供了遍历集合的方法。 根据GoF,迭代器设计模式的意图是: 提供一种在不暴露其基础表示…

random

1 import random2 3 result random.randint(1, 7) # 随机生成1到7的整数4 result random.random() # 随机生成[0,1)的浮点数5 result random.randrange(1, 7) # 随机生成1到7的整数6 result random.choice([1, 2, 3, 4]) # 从列表中随机选择一个元素7 result random.c…

面向对象 解释 经典啊

想必大家都知道面向对象三大特征:继承,封装,多态。 假如你现在有一个女朋友,那么现在你就可以称呼你的女朋友为对象啦。首先,你女朋友的身高三围等我们称作为属性,你如果想要跟你好基友分享一下你女朋友的身…

关于Unity实现AR功能(五)摄像头转换与闪光灯开关控制

1 /// <summary>2 /// 摄像头转换3 /// </summary>4 /// <param name"s_cameraDirection">摄像头转换方向</param>5 public void ChangeCameraDirectionMet(CameraDevice.CameraDirection s_cameraDirection)6 {7 …

并发编程(一):基础概述

本篇博客主要讲述并发编程中的一些基础内容&#xff0c;并了解一下基本概念。 首先我们了解一下什么是并发&#xff1f; 同时拥有两个或者多个线程&#xff0c;如果程序在单核处理器上运行&#xff0c;多个线程将交替的换入或者换出内存&#xff0c;这些线程是同时“存在”的&a…

Dumb Bones UVA - 10529(概率dp)

题意&#xff1a; 你试图把一些多米诺骨牌排成直线&#xff0c;然后推倒它们。但是如果你在放骨牌的时候不小心把刚放的骨牌碰倒了&#xff0c;它就会把相临的一串骨牌全都碰倒&#xff0c; 而你的工作也被部分的破坏了。 比如你已经把骨牌摆成了DD__DxDDD_D的形状&#xff0c;…

M - 非常可乐

1 #include <string.h>2 #include <stdio.h>3 #include <queue>4 using namespace std;5 6 int s,n,m;7 int vis[105][105][105];8 9 struct node10 {11 int s,n,m,step;12 };13 int check(int x,int y,int z)//平分条件14 {15 if(x 0 && y…

ArrayList和Vector的区别

这两个类都实现了List接口&#xff08;List接口继承了Collection接口&#xff09;&#xff0c;他们都是有序集合&#xff0c;即存储在这两个集合中的元素的位置都是有顺序的&#xff0c;相当于一种动态的数组&#xff0c;我们以后可以按位置索引号取出某个元素&#xff0c;并且…

【luogu1613】跑路 - 倍增+Floyd

题目描述 小A的工作不仅繁琐&#xff0c;更有苛刻的规定&#xff0c;要求小A每天早上在6&#xff1a;00之前到达公司&#xff0c;否则这个月工资清零。可是小A偏偏又有赖床的坏毛病。于是为了保住自己的工资&#xff0c;小A买了一个十分牛B的空间跑路器&#xff0c;每秒钟可以跑…

python哲学翻译_Python

正在学习Python开发语言的用户&#xff0c;可能会在学习过程中听说过讲师说过Python有一段有关于Python的哲学理念机设计思想&#xff0c;在Python里输入“import this”命令就会出现一段英文格言&#xff0c;这里我们把Python的这段格言的双语版分享出来&#xff0c;帮助正在学…

如何创建线程?

Java并发编程&#xff1a;如何创建线程&#xff1f; 在前面一篇文章中已经讲述了在进程和线程的由来&#xff0c;今天就来讲一下在Java中如何创建线程&#xff0c;让线程去执行一个子任务。下面先讲述一下Java中的应用程序和进程相关的概念知识&#xff0c;然后再阐述如何创建线…

经典MapReduce作业和Yarn上MapReduce作业运行机制

一、经典MapReduce的作业运行机制 如下图是经典MapReduce作业的工作原理&#xff1a; 1.1 经典MapReduce作业的实体 经典MapReduce作业运行过程包含的实体&#xff1a; 客户端&#xff0c;提交MapReduce作业。JobTracker&#xff0c;协调作业的运行。JobTracker是一个Java应用程…

根据Linux2.6.26源码分析进程模型

1.关于进程 1.1进程的概念 进程是正在运行的程序实体&#xff0c;并且包括这个运行的程序中占据的所有系统资源&#xff0c;比如说CPU(寄存器)&#xff0c;IO,内存&#xff0c;网络资源等。很多人在回答进程的概念的时候&#xff0c;往往只会说它是一个运行的实体&#xff0c;而…

socket编程开发

1.socket是什么&#xff1f; Socket是应用层与TCP/IP协议族通信的中间软件抽象层&#xff0c;它是一组接口。在设计模式中&#xff0c;Socket其实就是一个门面模式&#xff0c; 它把复杂的TCP/IP协议族隐藏在Socket接口后面&#xff0c;对用户来说&#xff0c;一组简单的接口就…

一个前端岗位电话面试所带来的问题的思考

这绝对不是一篇技术文&#xff0c;如果你不喜欢&#xff0c;也请不要喷&#xff0c;你可以看看都有哪些问题&#xff0c;当然&#xff0c;在这里你可能得不到问题的答案&#xff0c;不懂的你可能需要自己去百度&#xff0c;也可以在下面留言交流&#xff0c;我已经声明了&#…

Spring MVC –揭秘了@RequestBody和@ResponseBody

在这篇文章中&#xff0c;我想对Spring MVC进行一些深入的探讨&#xff0c;以揭示将请求转换为参数对象后在幕后发生的情况&#xff0c;反之亦然。 在开始之前&#xff0c;我想解释这些注释的目的。 RequestBody和ResponseBody是做什么用的&#xff1f; 它们是spring mvc框架的…