linux – 为什么这么多应用程序在不使用任何虚拟内存的情况下分
我一直在观看编程中的一些奇怪的现象已经有一段时间了,因为在 Linux系统上默认启用了overcommit. 在我看来,几乎每个高级应用程序(例如,用Java,Python或C#等高级编程语言编写的应用程序,包括用C编写的一些使用大型库(如Qt)的桌面应用程序)都使用疯狂的虚拟操作内存.例如,Web浏览器在使用仅300MB的RAM时分配20GB的内存是正常的.或者对于dektop环境,mysql服务器,几乎每个java或单声道应用程序等,都要分配数十GB的RAM. 为什么会这样?有什么意义?这有什么好处吗? 我注意到当我在linux中禁用overcommit时,如果桌面系统实际上运行了很多这些应用程序,系统就会变得无法使用,因为它甚至无法正常启动. 解决方法在虚拟机中运行代码的语言(如Java(*),C#或Python)通常在启动时分配大量(虚拟)内存.部分内容对于虚拟机本身是必需的,部分预先分配给虚拟机内的应用程序.对于在直接OS控制下执行的语言(如C或C),这不是必需的.您可以编写动态使用它们实际需要的内存量的应用程序.但是,一些应用程序/框架仍然以这样的方式设计,即它们从操作系统请求一次大块内存,然后自己管理内存,希望它比操作系统更有效. 这有问题: >它不一定更快.大多数操作系统已经非常聪明地管理他们的内存.优化,测量,优化,测量的规则#1. (编辑:淮安站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |