Re: Help on bit operation

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Aug 27, 2009 at 9:52 PM, Randi Botse<nightdecoder@xxxxxxxxx> wrote:
> Hi again.
>
> I was able to solve my bit packing/unpacking problems with bit mask
> and shift operations, but i have no idea how to do this using a
> bit-field structure, can someone give me a example?
>
> Thanks
>             - Randi
> --
> To unsubscribe from this list: send the line "unsubscribe linux-c-programming" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>

Glynn's example of bitfields is cleaner and better than this, but I
put a basic implementation of bitfields using your parameters at the
end of this message. From my understanding, the way bitfields are
implemented in C is with bit shifts and masks, so I don't think there
is a performance difference between the two.

#include <stdio.h>

struct bitfield {
    unsigned int a:6;
    unsigned int b:4;
    unsigned int c:8;
    unsigned int d:5;
    unsigned int e:9;
};

int main(void) {
    struct bitfield foo;
    foo.a =  43;
    foo.b =  11;
    foo.c = 120;
    foo.d =  30;
    foo.e = 418;
    printf("%u %u %u %u %u\n",foo.a,foo.b,foo.c,foo.d,foo.e);
    return 0;
}


Ben
--
To unsubscribe from this list: send the line "unsubscribe linux-c-programming" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Assembler]     [Git]     [Kernel List]     [Fedora Development]     [Fedora Announce]     [Autoconf]     [C Programming]     [Yosemite Campsites]     [Yosemite News]     [GCC Help]

  Powered by Linux