如何解决Java中是否有等效的内存映射烘焙数据结构在C ++中可能如此?
我有一个庞大的数据结构,需要立即有效地加载。实际上,这是许多TB的数据。大量的节点具有到其他节点的链接。这种数据结构必须以这样一种方式来烘焙:我可以站起来,一个服务可以访问它的任何部分,而不会出现毫秒级的启动延迟或每次访问的负担。
在C ++世界中,我将数据结构预先烘焙到文件中。然后有一些技巧可以使我将该文件映射到特定的虚拟地址,甚至可以预烘烤指针(尽管可以用偏移量替换指针并在操作系统放置的任何位置进行映射。)然后memmap文件和加载将有效地完成。一切都将立即可用,就像换出页面一样。
Java并不那么容易。充其量,我可以映射文件,然后在虚拟机中查找节点Java数据结构,但未能在其中找到它们,因此可以按需从地图上加载它们。我对这种解决方案不满意,因为它将产生更多的交换。如果节点的大小不恒定,也将需要更多的内存。
简而言之,如果我需要以一种可以在Java中直接引用的方式在文件中打包一个TB +大小的数据结构,该怎么办?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。