深入理解数组与指针——原因在于”退化“

(一)

数组与指针本质是不同的。如下图所示

char a[]="hello";
char *p="hello";

上述代码的初始化结果如下图所示:

a就是一个数组变量,表示整个数组。p是一个指针变量,存储的值是地址。

数组变量a和指针变量p,都存储在用户栈中。

而表达式char *p=”hello“中的”hello“是字面量,存储在静态只读存储区 .rodata区域。p存储的是”hello“的首元素地址

由此,可以看出数组和指针的区别有多大!!!

(二)

但有时候”似乎“数组可以当指针来用。根本原因在于:

数组除了在3种情况外,其他时候都要”退化“成指向数组首元素的指针

比如对 char s[5] = "china";
这3中例外情况是:
(1) sizeof(s)
(2) &s;
(3) 用来初始化s的"china";

也就是说,作为sizeof和&的操作数,以及作为初始化字符数组的字符串时,其他时候都要退化为指向数组首元素的指针。

(三)

用下面的例子来验证(一)(二)。

原文地址:https://www.cnblogs.com/renrenbinbin/p/4446122.html