• Lucy :3@feddit.org
    link
    fedilink
    arrow-up
    8
    ·
    3 days ago

    Then you need to ask yourself: Performance or memory efficiency? Is it worth the extra cycles and instructions to put 8 bools in one byte and & 0x bitmask the relevant one?

      • timhh@programming.dev
        link
        fedilink
        arrow-up
        2
        ·
        2 days ago

        It’s not just less memory though - it might also introduce spurious data dependencies, e.g. to store a bit you now need to also read the old value of the byte that it’s in.

        • Nat (she/they)@lemmy.blahaj.zone
          link
          fedilink
          arrow-up
          1
          ·
          18 hours ago

          Could definitely be worse for latency in particular cases, but if we imagine a write heavy workload it still might win. Writing a byte/word basically has to do the same thing: read, modify write of cache lines, it just doesn’t confuse the dependency tracking quite as much. So rather than stalling on a read, I think that would end up stalling on store buffers. Writing to bits usually means less memory, and thus less memory to read in that read-modify-write part, so it might still be faster.

        • anton@lemmy.blahaj.zone
          link
          fedilink
          arrow-up
          2
          ·
          2 days ago

          It might also introduce spurious data dependencies

          Those need to be in the in smallest cache or a register anyway. If they are in registers, a modern, instruction reordering CPU will deal with that fine.

          to store a bit you now need to also read the old value of the byte that it’s in.

          Many architectures read the cache line on write-miss.

          The only cases I can see, where byte sized bools seems better, are either using so few that all fit in one chache line anyways (in which case the performance will be great either way) or if you are repeatedly accessing a bitvector from multiple threads, in which case you should make sure that’s actually what you want to be doing.

      • Cethin@lemmy.zip
        link
        fedilink
        English
        arrow-up
        3
        ·
        3 days ago

        Yep, and anding with a bit ask is incredibly fast to process, so it’s not a big issue for performance.