I was looking through Shooter Game code, and I spotted usage of bit field for stuff like booleans etc. I come from Unity environment so I’m not used to them. However I love optimization so I will stick to them.
But what pros and cons we get from using it? How much it actually helps with RAM usage when more and more people have 8GB RAM. Dose it help with CPU cache?
I’d also like to know this. My suspicions are that defining a bool as “int32 bFoo:1;” reduces bandwidth overhead for network replication, since it only needs to pack 1 bit instead of 8/16/32 bits (whatever the default size of a bool is on the platform). But this is just a guess based on past C++ projects.
It is quicker in certain cases. Eg. if you use a regular bool (1 byte), and you need to set 8 bools to various values, you have to write 8 bytes. With 8 bits, you only need to write 1 byte.
Basically, you can compress many more into a single byte when using bit fields.
I’m not sure this is correct, as it really depends on the compiler and architecture. There is a performance overhead packing/unpacking bits, and many CPUs have instruction sets that are optimised for byte/word-aligned data structures. It definitely reduces memory overhead, though on modern platforms that’s negligible. I feel like there’s another reason at play.
There’s also considerations to make when thinking about the cache/instruction pipeline. Specifically the “cache line”. One should test if optimizations matter. I like having large counts of game objects in my worlds though and that generally means being very careful with memory not just for bandwidth but for the cache line’s sake. I guess it’s somewhat less important for polymorphic code that uses a ton of pointer logic. But it should still matter somewhat regardless at least in some areas. If your reading lots of data per frame there’s things that one can do to help, read contiguous, read less, avoid indirection as much as reasonably possible.
bit fields are usually used in very low level programming. In my case I’m unpacking a stream of data from a server where transmitting extra bits actually makes a difference. Also useful for setting options when communicating with hardware in device drivers.
They save me having to write the bit shifts and masking myself. I haven’t looked in a while, but I’ve found the compiler generated code for this sort of thing to be quite good.
For most game code I doubt the millionth of a second optimizations are worth worrying about.