- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我为自己创建了一个适用于 Windows (Win7 x64) 的 Java 渲染应用程序,它在渲染过程中确实使用了大量内存(在一些大型项目中实际上是演出……我的 PC 中有 8GB RAM 和 6 核 CPU ) 所以我必须在我的 .bat 文件中为它分配 4GB 甚至 8GB 的 RAM 来启动我的 java 应用程序,如下所示:
@ECHO OFF
java -Xmx8G -server -jar myapp %*
@if %errorlevel% neq 0 pause
当渲染过程结束时,它应该从物理内存中卸载所有不再需要的东西,并且根据我的应用程序内计算 ((r.totalMemory() - r.freeMemory())/(1024.0 * 1024) + "MB"
) 它确实做到了(我在渲染线程结束后调用 System.gc() :如果没有它,它不会报告内存使用量下降 - 它大约为 4GB,它报告大约 80MB 的已用内存)。
我的应用程序对 RAM 的使用基本上是这样的:
我什至使用了来自名为 Java VisualVM 的 JAVA bin 文件夹中的内存分析应用程序,以确保一切正常工作,没有任何内存泄漏......根据它的堆转储,它确实是这样工作的:
但我真的很困惑,为什么当我在 Windows 任务管理器中查看内存使用情况的 Windows 图时,内存使用量几乎完全没有下降(可能只有几 MB):它应该下降数百MB,如果不是数千(对于大型项目) - 它仅在我关闭我的应用程序后卸载。我真的等了 5 分钟、10 分钟、15 分钟......在那个图形窗口中仍然没有任何下降!
所以我想知道:我是否需要向我的 .bat 添加一些特定的开关来告诉 JVM“请卸载我的应用程序在渲染期间使用的所有未使用的内存”或者......?
最佳答案
Runtime.totalMemory()
返回 JVM 已从操作系统请求的内存量。在该内存中,“已使用”和“未使用”的概念仅与 Java 应用程序相关,与操作系统无关。所以 Runtime.freeMemory()
告诉您总内存中有多少内存可用于新分配,而这些值之间的差异告诉您有多少内存被 Java 对象占用,或者仍在使用中或尚未收集。
从操作系统的角度来看,totalMemory()
报告的值是应用程序请求的内存量,在简单系统中将被视为“正在使用”。因此,当 JVM 将内存返还给操作系统时,发生频率比垃圾回收低得多或根本不发生,具体取决于配置,totalMemory()
报告的数字将会减少。
不幸的是,像 Windows 这样的操作系统并没有那么简单。它有自己的“已用内存”概念,不同于请求的内存和 Java 的“使用中”概念。内存按页面组织,当应用程序实际写入其中时,Windows 将认为页面仅在使用中,因此它包含需要保留的内容。
此外,到目前为止讨论的所有内容都是“虚拟内存”,它映射到物理内存的方式是另一件复杂的事情。 Windows 将尝试将虚拟内存的页面映射到物理内存中的页面,但其他进程的内存需求可能会减少进程使用的物理内存。这个事实已被恶作剧工具利用, promise 通过简单地请求大量内存来“清理内存”,导致 Windows 重新分配物理内存,然后释放内存,因此使用的物理内存数量看起来非常低,因为它有已从正在运行的进程中取出,但当然,他们稍后会在继续时取回它,因此该操作只会降低性能。
要点是,如果不了解正在运行的应用程序实际需要什么,任务管理器中的图表可能会变得毫无意义。 “分配的(虚拟)内存”、“实际使用的(虚拟)内存”和“当前使用的(物理)内存”之间的关系不能用一个简单的图形来表达。
此外,虚拟机中的垃圾回收完成的主要任务是使虚拟机中的内存可用于同一虚拟机中的新分配,而不是将内存返还给操作系统。后者有时可能会发生,具体取决于配置,但一般不会发生。
关于Java 对 Runtime.memory() 与 Windows 的物理内存使用历史图的混淆,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57921646/
在 ARM 中,内存类型指定为: 正常 设备 强烈有序 在Device type里面,好像这个类型也可以区分 不可共享的设备内存 可共享设备内存 不可共享和可共享设备内存有什么区别?我们如何分别使用这
在 ARM 中,内存类型指定为: 正常 设备 强烈有序 在Device type里面,好像这个类型也可以区分 不可共享的设备内存 可共享设备内存 不可共享和可共享设备内存有什么区别?我们如何分别使用这
This diagram很清楚不同YARN和Spark内存相关设置之间的关系,除了spark.python.worker.memory。 spark.python.worker.memory 如何适应
我正在尝试使用复杂的if-else决策树来实现GLSL片段着色器。不幸的是,着色器编译器很早就失败,并出现“语法错误-内存耗尽”错误。 GLSL中的代码大小或决策树深度是否有任何限制?有什么建议如何克
什么是“标记内存”,它如何帮助减小程序大小? 最佳答案 您可能指的是 tagged union ,或更具体地说是硬件实现,如 LISP 机器中使用的标记架构。基本上是一种存储具有类型信息的数据的方法。
我的内存有问题。我不明白为什么当我的程序长时间运行时 Go 使用越来越多的内存(从不释放它)。 第一次分配后,程序使用了将近 9 MB 的内存。然后在 12 小时后,它开始以指数方式使用更多内存,直到
在 Windows 机器上,MATLAB 用户可以使用 memory或 feature memstats命令。但是,这些都不能在机器上工作,失败如下: >> memory??? Error using
引导 Linux 内核时,可以在 RAM 中加载 initramfs 存档和 DTB 文件,并将这些物理地址指定给内核。例如,使用 U-Boot,您可以执行以下操作: bootz 0x80008000
我正在学习虚拟内存的概念,但是这个问题让我困惑了一段时间。由于大多数现代计算机都使用虚拟内存,因此当程序正在执行时,操作系统应该在 RAM 和磁盘之间将数据分页进出。但为什么我们仍然遇到“内存不足”的
我在 Colab Pro+(使用高 RAM 选项)上运行神经网络时发现了这个问题。 运行时错误:CUDA 内存不足。尝试分配 8.00 GiB(GPU 0;15.90 GiB 总容量;12.04 Gi
当我在任何地方阅读基于操作系统的书籍时,考虑到时间限制和开销很高,从内存和 I\O(子系统)获取数据是昂贵的,这就是为什么在某些硬件制造商中提供一些其他方式来访问它们,如ARM7 some ISAs像
据我所知,ADS v.10 尝试将查询结果保留在内存中,直到它变得非常大。对于 __output 表和临时表也应该如此。当结果变大时,交换声明。 问题是为查询、 worker 等设置了什么内存限制?可
序言 我正在写一个小演示文稿来列出使用 Docker 时的一些“陷阱”,我也遇到了自己的一个问题。 在解释让 Docker 在没有内存限制的情况下运行的危险时,我发现它的行为不像我预期的那样。 我使用
我们有一个 ASP.NET 项目(40 个左右的 Web 表单、50 个表、相当标准的 IO 内容,并尽可能减少),很快需要部署。系统上大约有 100 个并发用户,但任何时候只有大约 20 个用户在使
我在 dotcloud 上使用 redis 内存存储,但尽管 key 已过期,但它的 used_memory 再也不会下降。从 redis-cli 使用 flushdb 或 flushall 不会导致
我使用的是 Xcode 10.2.1 和 macOS Catalina Developer Beta 2。每当我尝试使用内存图调试器时,我都会收到此错误: Memory Graph Debugger:
所以我一直在寻找这个问题的解决方案有一段时间了。我编写了一个程序来从两个单独的文本文件中获取数据,对其进行解析,然后输出到另一个文本文件和一个 ARFF 文件以供 Weka 分析。我遇到的问题是我编写
对不起,我对 erlang 文档中的以下描述不太清楚: erlang:memory() -> [{Type, Size}] with Type: "total" means: "The total a
在查看示例合约时,有时会在带有“内存”的方法中声明数组,有时则不会。有什么区别? 最佳答案 如果没有内存关键字,Solidity会尝试在存储中声明变量。 首席 Solidity 开发者 chriset
我不明白Matlab并行计算工具箱中的parfor cicle是如何与内存一起工作的:我读到它在所有worker之间共享内存(然后我认为每个worker(核心)都可以访问感兴趣的内存位置而无需制作本地
我是一名优秀的程序员,十分优秀!