Writing in the hole of a memory

I need to have a file where certain bytes are contiguously laid out. Lets call these chunks. The reason the chunks need to be laid out contiguously is that these eventually get memory-mapped to an array. A file would have several chunks(these correspond to different but related arrays), and these chunks need to be appended over time. The first thing I thought about is to use a sparse file and have holes at the inter-chunk boundaries.

Whenever I have new data I could then write in the hole. If the space available in the hole is not enough I intend to move minimum amount of bytes to create the space and (some extra space for future) and then write the data.

  • Is this a wrong way to do things ?
  • Are there good alternatives to this approach
  • How does the OS (Linux) handle a write in the hole, does it move(shift) all the bytes in the tail ? Or restructures the inodes to somehow accommodate (at the cost of fragmentation)
  • Is there an optimal way to do this so that amortized movement cost is small

  • Most likely, yes.

  • Linux already comes with a system for tracking multiple, contiguous byte sequences with efficient appends: the file system. Can't you just use multiple files?

  • If you use a modern Linux fs (ie not FAT32), it'll leave the existing data in place and allocate additional space. This could be either in a pre-allocated extent/block or by fragmentation. It's left to the FS to figure that out.

  • "Optimal" depends on your usage patterns and how much you value time vs space. It's hard to make general comments, but there are many CS papers on how to allocate and reallocate chunks of bytes given various assumptions.

  • 链接地址: http://www.djcxy.com/p/26958.html

    上一篇: NHibernate不会持续DateTime SqlDateTime溢出

    下一篇: 写在记忆的洞里