结构体在深入一步的问题
今天看了一篇关于结构体的文章写得很好引用:原地址:https://coolshell.cn/articles/11377.html,文章作者陈皓,虽然大体知道缘故 但是没事没太懂 而且Test结构体输出字节是8,f是4
大神来点一点{:10_266:}
#include <stdio.h>
struct str
{
char len;//1
int lens;//4
char s;
}Test;
struct foo
{
struct str *a;
}f = {0};
int main(void)
{
//struct foo f = {0};
printf("struct str sizeof = %d\n",sizeof(Test)); //占了5个字节 输出结果是8
printf("struct foo sizeof = %d\n",sizeof(f));
if( f.a->s )
{
printf("%x\n",f.a->s);//我知道是0x4 访问地址的问题导致下一行代码f.a->s被crash
printf(f.a->s);
}
return 0;
}
结构体定义char s的妙处也没看太懂 在你看来应该输出什么? 人造人 发表于 2018-6-2 17:34
在你看来应该输出什么?
如果没错的话,结构体先申请char,然后因为int为4个字节,所以说调整后需要与现在分配的空间的倍数,所以也是4+4=8。但是后面的就想不通了 比如结构体定义char妙处 及 结构体里定义另一个结构体指针..绕绕的 理想小青年 发表于 2018-6-2 17:42
如果没错的话,结构体先申请char,然后因为int为4个字节,所以说调整后需要与现在分配的空间的倍数,所以 ...
printf("struct str sizeof = %d\n",sizeof(Test)); //占了5个字节 输出结果是8
printf("struct foo sizeof = %d\n",sizeof(f));
输出 8 和 4 能理解吗?
人造人 发表于 2018-6-2 17:46
printf("struct str sizeof = %d\n",sizeof(Test)); //占了5个字节 输出结果是8
printf("struct...
8能理解 编译器的一种调整方式结构体变量指针大小理解不好 理想小青年 发表于 2018-6-2 17:48
8能理解 编译器的一种调整方式结构体变量指针大小理解不好
struct foo
{
struct str *a;
}f = {0};
struct foo
{
int *a;
}f = {0};
这两个有区别吗?
一个是结构体指针
另一个是int指针
都是指针
指针,32位环境,4个字节
人造人 发表于 2018-6-2 17:52
这两个有区别吗?
一个是结构体指针
另一个是int指针
{:10_269:}指针本质是没区别的,这两个不同于指向的对象不同 。原来这样,就是占4个字节。我以为指针存放的是地址,字节大小根据指针存放的地址动态扩充...自己想多了 还是不了解 人造人 发表于 2018-6-2 17:52
这两个有区别吗?
一个是结构体指针
另一个是int指针
能讲讲char s的妙处吗小达人,为什么结构体引用一个不占内存的数组 理想小青年 发表于 2018-6-2 17:59
指针本质是没区别的,这两个不同于指向的对象不同 。原来这样,就是占4个字节。我以为指针存放 ...
指针就只是一个地址,32位环境,4个字节
不管是什么指针,是不是包装在结构体中,都只是4个字节
人造人 发表于 2018-6-2 18:04
指针就只是一个地址,32位环境,4个字节
不管是什么指针,是不是包装在结构体中,都只是4个字节
{:10_315:} 理想小青年 发表于 2018-6-2 18:00
能讲讲char s的妙处吗小达人,为什么结构体引用一个不占内存的数组
sizeof(t): 4 // 因为s不占内存,这个4是x的
x的地址和s的地址相差4
因为x从偏移0的位置存放,s的偏移就是4,s只有地址,没有内存空间(^_^),这个有意思,我第一次见
页:
[1]