Chinaunix首页 | 论坛 | 博客
  • 博客访问: 195694
  • 博文数量: 51
  • 博客积分: 1435
  • 博客等级: 上尉
  • 技术积分: 590
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-05 18:33
文章分类

全部博文(51)

文章存档

2012年(17)

2011年(34)

分类: C/C++

2011-09-06 19:59:45

这几天在看c语言深度解剖。
大小端的问题困扰了自己好长时间,最近在看这本书的时候又重新翻出来了。跟军军请教了后清晰多了。
测试大小端的代码:
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int checkSystem();
  4. int main()
  5. {
  6.     int test = checkSystem();

  7.     printf("%d\n",test);
  8.     return 0;
  9. }
  10. int checkSystem(){
  11.     union check{
  12.         int i;
  13.         char ch;
  14.     }c;
  15.     c.i = 1;

  16.     return (c.ch == 1);

  17. }
  18. 附录:经典题目:
  19. x86 系统下,输出的值为多少?

    #include

    intmain()

    {

    int a[5]={1,2,3,4,5};

    int *ptr1=(int *)(&a+1);

    int *ptr2=(int *)((int)a+1);

    printf("%x,%x",ptr1[-1],*ptr2);

    return 0;

    }

阅读(2957) | 评论(7) | 转发(1) |
0

上一篇:堆和栈的区别

下一篇:gdb调试学习

给主人留下些什么吧!~~

sygspjlsj2011-09-13 08:58:24

林生2010: 下面这段代码确实有点意思:
关键是要弄清楚ptr1和prt2分别指向的地址是什么:
      prt1 --> &a+1,其中&a是指数组a的地址,&a+1就是数组a的首.....
厉害啊!谢谢你的回复!

rainballdh2011-09-11 23:04:40

main:
        pushl        %ebp
        movl        %esp, %ebp
        andl        $-16, %esp
        subl        $48, %esp

        movl        $1, 20(%esp)
        movl        $2, 24(%esp)
   

林生20102011-09-08 19:57:43

Radish_Hu: 林生2010解释的很清楚,有一点要补充一下,1.ptr[-1] :*(ptr-1).2.就是文中提到的大小端问题。林生2010例子中是小端。大端的话输出还是有区别的。欢迎来交流!呵.....
x86就是小端模式,所以我就按照小端模式的情形来讲解了 呵呵

Radish_Hu2011-09-08 16:18:06

林生2010解释的很清楚,有一点要补充一下,1.ptr[-1] :*(ptr-1).2.就是文中提到的大小端问题。林生2010例子中是小端。大端的话输出还是有区别的。欢迎来交流!呵呵

林生20102011-09-08 12:09:27

下面这个例子不错,前段时间我也写过类似的文章,但是这个例子还是初次看到,不错,copy回去完善一下我的那篇文章 呵呵。