在对数组或者接收到的数据进行赋值时,往往因为结构体中含有指针而无法获取接收到的数据,那么如何才能获取结构体中的指针指向的内容呢?这就涉及到两个部分的内容。
1、通过memcpy()赋值或者对数据进行结构体的强制类型转换,其中的指针如何指向?
以下通过一个实际的例子进行解析
typedef struct
{
/* data */
int a;
int b;
void* c;
}test;
int main(int argc, char const *argv[])
{
test* aa;
int array[] = {1, 2, 3, 4, 5, 6};
aa = (test *)array;
printf("aa:%d\n", aa->a);
printf("aa:%d\n", aa->b);
//此时输出的是3,这是因为aa->c实际上是aa->*c是一个指针,即*c = array[2]
printf("aa:%d\n", aa->c);
//(int *)&(aa->c)是指针的强制类型转换,此时在外层加上*()是对指针取值
printf("aa:%d\n", *((int *)&(aa->c)));
return 0;
}
结果:
aa:1
aa:2
aa:3
aa:3
aa->b 此时输出的是3 ,这是因为aa->c 实际上是aa->*c 是一个指针,即*c = array[2] (int *)&(aa->c) 是指针的强制类型转换,此时在外层加上*() 是对指针取值
2、通过以上方式进行赋值之后,此时结构体的大小是多少呢?是3*sizeof(int) 么?
此时在main 函数中增加对结构体尺寸的打印以及void * 的尺寸打印
printf("aa:%d\n", sizeof(test));
printf("aa:%d\n", sizeof(void *));
结果:
aa:16
aa:8
这就意味着结构体中除了两个int类型的数据之外还有一个指针,指针实质上是地址,因此在64位的平台上,指针的大小为8个字节。
|