草庐IT

C++流到内存

全部标签

内存中的Java原始数组布局

以下是我提出问题的两个示例(假设您在此处有JOL):Layouterlayout32Bits=newHotSpotLayouter(newX86_32_DataModel());Layouterlayout64BitsComp=newHotSpotLayouter(newX86_64_COOPS_DataModel());还有一个使用这个的例子:int[]ints=newint[10];System.out.println(ClassLayout.parseInstance(ints,layout32Bits).toPrintable());System.out.println(Cla

java - 如何获取Java堆的内存地址?

如何确定当前进程中运行的JVM的Java堆在内存中的地址?也就是说,使用Java、C或其他调用获取一个void*指针或等效于JVM为堆分配的连续内存区域?Matlab在其进程中嵌入了一个JVM。JVM分配的内存不可用于Matlab数组,其中,堆很重要,因为它占用了一大块连续的内存并且从不收缩,而Matlab的数组也需要连续的内存。如果在扩展期间重新分配堆,可能会导致碎片。我想检测我的进程来检查Java堆和Matlab的内存View之间的交互,并找出它何时因调整大小而移动,最好是在进程内。这需要堆的地址。从java.lang.Runtime很容易找到堆大小,但不是它在内存中的地址。如何做

java - Swing 拖放导致内存泄漏

我有一个JFrame可以接受顶级文件。但是,在发生丢弃之后,对框架的引用将无限期地保留在某些Swing内部类中。我相信处理框架应该释放它的所有资源,那么我做错了什么?例子importjava.awt.datatransfer.DataFlavor;importjava.io.File;importjava.util.List;importjavax.swing.JFrame;importjavax.swing.JLabel;importjavax.swing.TransferHandler;publicclassDnDLeakTesterextendsJFrame{publicstat

java - 防止 ConcurrentLinkedQueue<T> 出现内存不足异常

使用ConcurrentLinkedQueue时,如何限制队列的大小。是否有可能通过内存不足异常? 最佳答案 ConcurrentLinkedQueue的大小是无限的,所以如果生产者放入元素的速度快于消费者移除元素的速度,最终它确实会耗尽你的内存。如果你想限制队列的大小,试试阻塞队列,比如LinkedBlockingQueue或ArrayBlockingQueue反而。第一个的大小可以有选择地限制,而第二个总是有限制的。 关于java-防止ConcurrentLinkedQueue出现内

java - 避免回调中的内存泄漏?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Howtoavoidmemoryleaksincallback?EffectiveJava说:Athirdcommonsourceofmemoryleaksislistenersandothercallbacks.IfyouimplementanAPIwhereclientsregistercallbacksbutdon’tderegisterthemexplicitly,theywillaccumulateunlessyoutakesomeaction.Thebestwaytoensurethatcallb

java - 如何让JVM释放内存给OS

这个问题在这里已经有了答案:DoesGCreleasebackmemorytoOS?(5个答案)关闭4年前。我正在为我的应用程序使用GC选项XX:+UseParNewGC-XX:+UseConcMarkSweepGC。正如你们中的大多数人已经体验到的那样,JVM擅长将堆增加到最大堆大小,但是它不会将内存释放回操作系统。我遇到了-XX:MaxHeapFreeRatio和-XX:MinHeapFreeRatio但并行垃圾收集器忽略了这些。-XX:MaxHeapFreeRatio和-XX:MinHeapFreeRatio组合是否有强制JVM将内存释放回操作系统的特殊选项。

java - Java 数组在 HotSpot 中使用内存的精确程度如何(即多少 slop)?

Cmalloc实现通常不会分配请求的精确内存量,而是消耗固定大小的内存运行,例如具有二次方大小,因此1025字节的分配实际上占用了2048字节的段,其中1023字节作为slop丢失。HotSpot是否对Java数组使用类似的分配机制?如果是这样,分配Java数组的正确方法是什么,这样就没有溢出?(例如,数组长度应该是2的幂还是2的幂减去一些固定的开销?) 最佳答案 如果您问的是语言,答案是:未指定(与C相同)如果您询问的是具体实现,请查看该实现。我相信Hotspot的粒度是8字节;即对象大小向上舍入到下一个粒度边界。如果问题是关于在

java - 部署在 Wildfly 8.2.1 上的 Java 8 应用的 Metaspace 内存消耗问题

问题描述我注意到,我们的Java8应用程序之一在Wildfly8.2.1上的每次部署都会使用元空间内存池中的大约30-40MB。这很好,但问题是,一旦我重新部署同一个应用程序,Metaspace内存使用量就会增加同样的30-40MB,而旧的已经分配的内存不会被释放。我什至不会注意到它,但问题是我们有大约20个应用程序,有时我需要同时重新部署多达10个应用程序。这反过来会导致一幅可怕的画面。基本上显示的是大约10个应用程序的2次重新部署。我不确定为什么GC不能释放分配给旧类的内存。该服务器总共有16GB物理内存,因此我可以重新部署所有应用程序多达20-40次,仅此而已。应用服务器将达到限

java - 在 h2o 中加载大于内存大小的数据

我正在试验在h2o中加载大于内存大小的数据。H2oblog提到:关于更大数据和GC的注释:当Java堆太满时,我们会执行用户模式磁盘交换,即,您使用的大数据多于物理DRAM。我们不会死于GC死亡螺旋,但我们会降级到超出核心的速度。我们将按照磁盘允许的速度进行。我亲自测试过将12Gb数据集加载到2Gb(32位)JVM中;加载数据大约需要5分钟,运行逻辑回归又需要5分钟。这是连接到h2o3.6.0.8的R代码:h2o.init(max_mem_size='60m')#alloting60mbforh2o,Risrunningon8GBRAMmachine给予javaversion"1.8.

java - volatile 变量并刷新到主内存/从主内存读取

官方注释说,那Writingtoavolatilefieldhasthesamememoryeffectasamonitorrelease,andreadingfromavolatilefieldhasthesamememoryeffectasamonitoracquire.和Effectively,thesemanticsofvolatilehavebeenstrengthenedsubstantially,almosttothelevelofsynchronization.Eachreadorwriteofavolatilefieldactslike"half"asynchroni