指针运算问题

 

 

#include <stdio.h>
#include <stdlib.h>

struct num {
    long  num1;
    char  num2;
    short num3;
    long  num4[5];
    short num5[5];
};

int main(void)
{
    struct num *p;
    p  = 0x100000;
    printf("           sizeof(struct num) = %d\n", sizeof(struct num));
    printf("                                     p     = %x\n", p);
    printf("                                 p+0x1 = %x\n", p+0x1);
    printf("                      (long)p+0x1 = %x\n", (long)p+0x1);
    printf("    (unsinged long)p+0x1 = %x\n", (unsigned long)p+0x1);
    printf(" (unsinged long *)p+0x1 = %x\n", (unsigned long *)p+0x1);
    printf("                      (char)p+0x1 = %x\n", (char)p+0x1);
    printf("                    (char*)p+0x1 = %x\n", (char*)p+0x1);
    printf("                    (short)p+0x1 = %x\n", (short)p+0x1);
    printf("                  (short*)p+0x1 = %x\n", (short*)p+0x1);
   
    return 0;
}

 

结果:

         sizeof(struct num) = 40
                      p                  = 100000
                       p+0x1         = 100028
                  (long)p+0x1    = 100001
   (unsinged long)p+0x1 = 100001
(unsinged long *)p+0x1 = 100004
                     (char)p+0x1 = 1
                   (char*)p+0x1 = 100001
                    (short)p+0x1 = 1
                   (short*)p+0x1 = 100002

 

             此题目的重点在于先求出结构体的长度,字节对齐问题,指针的运行问题及强制转化后0X1的长度,还要考虑强制转化后变量能否存入p的值。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值