Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1042191
  • 博文数量: 243
  • 博客积分: 3053
  • 博客等级: 中校
  • 技术积分: 2975
  • 用 户 组: 普通用户
  • 注册时间: 2009-05-02 21:11
文章分类

全部博文(243)

文章存档

2013年(2)

2012年(20)

2011年(5)

2010年(114)

2009年(102)

我的朋友

分类:

2010-11-15 10:02:36

c语言中指针和数组在编译时的区别 例如:int a[10]和int *b,a[5]和*(b+5) 在编译的时候区别是什么? 经过反复的查资料和请教他人,最后在《c专家编程》里找到了很好的答案。

    1。编译器对数组名和指针变量的处理方式
编译器在编译时会产生一个符号表,记录了符号名和它的地址。对于指针变量,这显然很好理解。而数组名就不那么明显了,它仅仅是一个符号而已,何来地址?编译器是这样处理的,它记录了array[0]的地址;这和我们通常的理解也是一样的。
    2。带下标形式的数组和指针寻址方式
        (1)数组情形
            char a[9]="abcdefgh";
            ...
            c=a[i];
           

            在编译期,会在符号表中创建这样一条记录:
            name:a  address:9980
            要获取a[i]的值分两个步骤:
            step 1:取得i的值并和9980相加
            step 2:在内存地址(9980+i)处取其内容

        (2)指针情形
            char* p="abcdefgh";
            ...
            c=p[i];
            在编译期,会在符号表中创建这样一条记录:
            name:p  address:4624
            要获取p[i]的值分三个步骤:
            step 1:在内存地址4624处取其内容,比如说“5081”
            step 2:取得i的值并和5081相加
            step 3:在内存地址(5081+i)取其内容

阅读(1163) | 评论(0) | 转发(0) |
0

上一篇:Visual Studio使用技巧

下一篇:C++ 谓词对象

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