consider the following structure:
typedef struct __attribute__((packed)) a{
int a1;
int b2;
char cArray[5];
int c3;
} Mystruct;
Now in my code, Im doing this:
char source[50];
Mystruct mm;
//...
//initialization and other codes
//...
memcpy(&mm,source,sizeof(mm));
I am trying to fill up the structure from a string (from a file to be more specific), and hence I don't want the padding. But think packing affects the performance also.
So my question is, is there any other way to accomplish what I want?
Is it possible to do the same (filling up from a string) with member variables of a class in c++? If yes, how?
I'd highly recommend you purchase and read Write Portable Code. You don't want to take this approach. Not only because it isn't portable (think endianess issues), but it does impact performance and atomicity (non-aligned 32-bit access is not atomic on x86 without a LOCK prefix). It's much better to marshal/unmarshal, even though it's a bit more work up front.
The idea behind marshaling/unmarshaling is to convert your data from one format to another, and them back again. This is what frameworks like Google Protocol Buffers, ZeroMQ, and many others do to transfer data in a portable way. You basically have specialized functions that take your "string" data that you spoke of, and you parse it, validate it, and then assign it into your structure. You'll see marshaling and serialization used interchangeably in many contexts.
For instance, in your case, you might have a function with the prototype:
int
unmarshal_mystruct(const char *data, MyStruct &m);
Internally, you'd parse the data from data
, and populate m
. It does get tedious which is why so many people use the frameworks.