开发者

initializing a value to a structure

开发者 https://www.devze.com 2023-02-18 02:38 出处:网络
struct mac_filter { 开发者_如何学JAVAchar ether_dhost[6]; char ether_shost[6]; short ether_type; }; struct packet_filter
  struct mac_filter
    {
     开发者_如何学JAVA   char ether_dhost[6];
        char ether_shost[6];
        short ether_type;
    };

    struct packet_filter
    {
        struct mac_filter mac;
    };

    main()
    {
    struct packet_filter test;
    test.mac= NULL;
    }

i get

error: incompatible types when assigning to type ‘struct mac_filter’ from type ‘void *’

here i want to initialize all the member function of mac_filter to zero, is there any way to set them to zero instead to initializing each member functions to zero


Your struct contains an actual struct mac_filter, not a pointer to one. You can't assign NULL to it.

If you wanted a pointer to one, your struct would look like:

struct packet_filter
{
    struct mac_filter *mac;
};

To use it you would need to malloc() memory to it, or assign a pointer to it.

If you just want to zero out your struct, you use memset and pass a pointer to your struct:

memset(&test.mac, 0, sizeof (struct mac_filter));


It's actually faster to memset them all to zero and then fill in the values as they become available later.

However I recommend you use C99 initialization when you know all the values:

struct packet_filter test = {
    .mac = (struct mac_filter) {
        .ether_dhost = {0, 0x11, 0x22, 0x33, 0x44, 0x55},
        .ether_shost = {0xff, 0xee, 0xdd, 0xcc, 0xbb, 0xaa};
    },
};

Any values you don't set are automatically initialized to zero. In this case I've left mac.ether_type as 0.

Note that this kind of initialization is very popular with initializing C-style jump tables at both compile time and run time, among other kinds of arrays that are sparsely populated, or index/member fields being set are very specific.


Maybe I don't understand your question correctly but default initialization is doing just what you want:

int main(void)
{
    struct mac_filter test = { 0 };
}

By default that initialization sets all fields recursively to the "correct" form of 0. In most cases this is equivalent to memset but you never know what your target architecture has as specialities.

And if you want to assign to that part (this is something different than initialization) you may use a "compound literal" from C99:

test.mac = (const packet_filter){ 0 };

BTW, the code that you posted is completely bogus. The type of your declaration is not correct and your definition of main is ridiculous. Please post code that is as correct as possible so we can concentrate on the actual problem for the question.


You can use memset:

memset(&test.mac, 0, sizeof (test.mac));

See the manual page of the memset function.


Use memset in C

memset(&test.mac, 0, sizeof (struct mac_filter));


better you define it as global variable. and default value of global variable is zero.

0

精彩评论

暂无评论...
验证码 换一张
取 消