The question shown below is an interview question:
Q) You are given/have a datatype, say X in C.
The requirement is to get the size of the datatype, without decl
Declare a structure with a member of that type, then use offsetof to compute the size?
struct outer
{
X x;
char after;
};
offsetof(outer, after) should give you the (aligned) size of x. Note that I'm not declaring a variable of that type per se, nor a pointer to the type, but I'm including it as a member of a structure declaration, where I measure the location of the member that comes after it.
The offsetof macro can be defined as
#define offsetof(S, f) ((size_t)(&((S *)0)->f))
You can typecast 0 (or any arbitrary value) to type datatype X* to find the size of the datatype, just like the below example:
#include <stdio.h>
struct node{
char c;
int i;
};
int main()
{
printf("Sizeof node is: %d\n", ((char *)((struct node *)0 + 1) - (char *)((struct node *)0)));
// substract 2 consecutive locations starting from 0 that point to type node,
//typecast these values to char * to give the value in number of bytes.
return 0;
}
The original is from this discussion. http://www.linuxquestions.org/questions/programming-9/how-to-know-the-size-of-the-variable-without-using-sizeof-469920/
This should do the trick:
#include <stdio.h>
typedef struct
{
int i;
short j;
char c[5];
} X;
int main(void)
{
size_t size = (size_t)(((X*)0) + 1);
printf("%lu", (unsigned long)size);
return 0;
}
Explanation of size_t size = (size_t)(((X*)0) + 1);
sizeof(X) would return 12 (0x0c) because of alignment((X*)0) makes a pointer of type X pointing to memory location 0 (0x00000000)+ 1 increments the pointer by the the size of one element of type X, so pointing to 0x0000000c(size_t)() casts the address, that is given by the expression (((X*)0) + 1) back to an integral type (size_t)Hope that gives some insight.
printf("%d",(int)(&x+1)-(int)&x