导读 您好,今天小编胡舒来为大家解答以上的问题。数组名代表的是数组所占存储区的首地址,数组定义后数组名的值是一个地址可以被修改相信很多小...

您好,今天小编胡舒来为大家解答以上的问题。数组名代表的是数组所占存储区的首地址,数组定义后数组名的值是一个地址可以被修改相信很多小伙伴还不知道,现在让我们一起来看看吧!

1、数组名是数组的首地址,就是数组中第一个元素的地址,是常量。

2、常量是不能出现在赋值号=左边作为左值的。

3、楼上的都没有解释清楚,说数组名就是指针是错误的,指针是变量,是用来存储变量地址值的变量,而数组名是常量。

4、一般情况下声明一个数组,比如char a[10];之后,数组名a都是数组的首地址,是一个地址常量。

5、但是在函数声明的形参列表中除外。

6、比如:int foo(char a[10]);在这种情况下这样的声明与int foo(char a[]);int foo(char * a);是等价的,就是说这种情况下,就算你写的是数组的形式,编译器实际处理的时候也当指针来处理(注意指针是变量,形参也是变量,二者刚好对应)。

7、所以在函数foo内部,你对a进行++, --, +=,=之类的带赋值的操作是完全合法的,因为此时a就是一个指针,不是数组名,当你往函数foo里面传入一个已经事先声明的数组的首地址时候,指针a里面的值就是你这个已经声明的数组的首地址,这样你在foo里面就可以对你那个数组进行操作,正是因为C有这个传地址的优点,所以省略了很多不必要的拷贝工作,试想如果没有这个传地址,你传一个有几万个元素的数组进去,那拷贝工作是相当可观的。

8、这样,你该明白了int main(int argc, char ** argv);里面为什么可以对argv进行++操作了,既然“main函数的第二个形参是一个指向字符串的指针数组”,argv出现在函数声明中,所以它实际上是一个指针,它并不是“一个指向字符串的指针数组”,而是一个可以获取“一个指向字符串的指针数组”的首地址值的变量。

9、楼主,请结合我前面的讲解,仔细体会我前面这句话的意思。

10、国内的教材不知道怎么写的,把别人越讲越晕。

11、如果不明白,尽管发消息问我。

本文就为大家分享到这里,希望小伙伴们会喜欢。