标题:C语言:结构体与地址运算问题,不知道怎么算,谁帮忙指点一二,谢谢了!!
只看楼主
weishen2011
Rank: 2
等 级:论坛游民
帖 子:92
专家分:70
注 册:2012-10-16
结帖率:80%
已结贴  问题点数:20 回复次数:7 
C语言:结构体与地址运算问题,不知道怎么算,谁帮忙指点一二,谢谢了!!
#include<stdio.h>
#include<stdlib.h>
struct
{
      long num;
      char *name;
      short i;
      char j;
      short a[5];
}*p;
int main()
{
    printf("p+0x200=%p\n",p+0x200);
    printf("(unsigned long)p+0x200=%p\n",(unsigned long)p+0x200);
    printf("(char *)p+0x200=%p\n",(char *)p+0x200);
    system("pause");
    return 0;
}
输出结果分别是00003000,00000200,00000200,
为什么啊??
搜索更多相关主题的帖子: long include system return 
2012-11-23 11:20
a635958000
Rank: 4
等 级:业余侠客
帖 子:55
专家分:253
注 册:2012-10-26
得分:10 
你结构体定义的有问题吧。
#include<stdio.h>
#include<stdlib.h>
struct student
{
      long num;
      char *name;
      short i;
      char j;
      short a[5];
};
int main()
{
    struct student *p;
    printf("p=%p\n",p);
    printf("p+0x200=%p\n",p+0x200);
    printf("(unsigned long)p+0x200=%p\n",(unsigned long)p+0x200);
    printf("(char *)p+0x200=%p\n",(char *)p+0x200);
    system("pause");
    return 0;
}
2012-11-23 11:48
weishen2011
Rank: 2
等 级:论坛游民
帖 子:92
专家分:70
注 册:2012-10-16
得分:0 
以下是引用a635958000在2012-11-23 11:48:55的发言:

你结构体定义的有问题吧。
#include<stdio.h>
#include<stdlib.h>
struct student
{
      long num;
      char *name;
      short i;
      char j;
      short a[5];
};
int main()
{
    struct student *p;
    printf("p=%p\n",p);
    printf("p+0x200=%p\n",p+0x200);
    printf("(unsigned long)p+0x200=%p\n",(unsigned long)p+0x200);
    printf("(char *)p+0x200=%p\n",(char *)p+0x200);
    system("pause");
    return 0;
}

结构体定义应该没问题,可以不定义结构体名而直接在后面定义结构体变量的,现在关键就是不知道后面他的地址怎么算出来的?
2012-11-23 11:57
a635958000
Rank: 4
等 级:业余侠客
帖 子:55
专家分:253
注 册:2012-10-26
得分:0 
回复 2楼 a635958000
第一个输出中p+0x200应该是输出p地址加上200个结构体后的地址,一个结构体所占的内存为15,200就是3000了
而下面的就是简单的地址相加了。
2012-11-23 12:28
a635958000
Rank: 4
等 级:业余侠客
帖 子:55
专家分:253
注 册:2012-10-26
得分:0 
回复 楼主 weishen2011
上面解释错误了,不红意思,
结构体的长度为24,0x200是16进制表示成十进制为512,那么应该将地址向后移动
24*512个位置,而512*24表示成16进制为3000
2012-11-23 12:54
weishen2011
Rank: 2
等 级:论坛游民
帖 子:92
专家分:70
注 册:2012-10-16
得分:0 
以下是引用a635958000在2012-11-23 12:54:08的发言:

上面解释错误了,不红意思,
结构体的长度为24,0x200是16进制表示成十进制为512,那么应该将地址向后移动
24*512个位置,而512*24表示成16进制为3000

什么意思啊,完全看不懂啊!
对了,题目中有个条件好像忘了,就是结构体中变量要遵循4个字节对齐,这样的话求出的结构体大小不是24吧,我怎么算出好像是36呢?
2012-11-23 18:20
a635958000
Rank: 4
等 级:业余侠客
帖 子:55
专家分:253
注 册:2012-10-26
得分:0 
#include<stdio.h>
#include<stdlib.h>
#include"string.h"
struct student
{
      long num;
      char *name;
      short i;
      char j;
      short a[5];
};
int main()
{     
    int len;
    struct student a,*p;
    printf("%d\n",sizeof(a));//是24啊,你看看
    printf("p=%x\n",p);
    printf("p+0x200=%x\n",p+0x200);
    printf("(unsigned long)p+0x200=%x\n",(unsigned long)p+0x200);
    printf("(char *)p+0x200=%x\n",(char *)p+0x200);
    system("pause");
    return 0;
}
2012-11-26 10:32
lxsjzbd
Rank: 4
来 自:河北省
等 级:业余侠客
帖 子:97
专家分:258
注 册:2012-3-31
得分:10 
你的p没有赋初值,貌似系统自动分配的0,所以16进制表示就是0x00000000;
16进制0x0200是10进制512,而%p就是以16进制表示的地址值
还有就是:p+0x0200就是p+512;
这个会由p指向的类型决定移动的字节数,因为p指向结构体,而结构体根据边界对齐是24个字节;
所以p+512=0x00000000+24*512结果用16进制表示就是0x00003000
你可以用数组理解下(32位系统):
int a[10];
(int)(a+1)=(int)a+4;
2012-11-26 12:16



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-388059-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.306084 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved