c语言中数组名代表数组首地址,它的值在运行期间可以改变吗?
c语言中数组名代表数组首地址,它的值在运行期间是固定不变的,但是在main函数的参数中对指针数组名却可以出现类似于argv++的操作(谭浩强老师的c程序设计中有这样的程序...
c语言中数组名代表数组首地址,它的值在运行期间是固定不变的,但是在main函数的参数中对指针数组名却可以出现类似于argv++的操作(谭浩强老师的c程序设计中有这样的程序),这不是前后矛盾了吗?盼高手解决,谢谢。
首先谢谢大家的回答,谭老师的书中写道“main函数的第二个形参是一个指向字符串的指针数组”(也就是argv)。既然它是一个数组,而数组名代表首地址不能改变,也就不应当出现类似于argv++的操作了 展开
首先谢谢大家的回答,谭老师的书中写道“main函数的第二个形参是一个指向字符串的指针数组”(也就是argv)。既然它是一个数组,而数组名代表首地址不能改变,也就不应当出现类似于argv++的操作了 展开
展开全部
数组名是数组的首地址,就是数组中第一个元素的地址,是常量。常量是不能出现在赋值号=左边作为左值的。楼上的都没有解释清楚,说数组名就是指针是错误的,指针是变量,是用来存储变量地址值的变量,而数组名是常量。一般情况下声明一个数组,比如char a[10];之后,数组名a都是数组的首地址,是一个地址常量。但是在函数声明的形参列表中除外。
比如:
int foo(char a[10]);
在这种情况下这样的声明与
int foo(char a[]);
int foo(char * a);
是等价的,就是说这种情况下,就算你写的是数组的形式,编译器实际处理的时候也当指针来处理(注意指针是变量,形参也是变量,二者刚好对应)。所以在函数foo内部,你对a进行++, --, +=,=之类的带赋值的操作是完全合法的,因为此时a就是一个指针,不是数组名,当你往函数foo里面传入一个已经事先声明的数组的首地址时候,指针a里面的值就是你这个已经声明的数组的首地址,这样你在foo里面就可以对你那个数组进行操作,正是因为C有这个传地址的优点,所以省略了很多不必要的拷贝工作,试想如果没有这个传地址,你传一个有几万个元素的数组进去,那拷贝工作是相当可观的。这样,你该明白了int main(int argc, char ** argv);里面为什么可以对argv进行++操作了,既然“main函数的第二个形参是一个指向字符串的指针数组”,argv出现在函数声明中,所以它实际上是一个指针,它并不是“一个指向字符串的指针数组”,而是一个可以获取“一个指向字符串的指针数组”的首地址值的变量。楼主,请结合我前面的讲解,仔细体会我前面这句话的意思。国内的教材不知道怎么写的,把别人越讲越晕。如果不明白,尽管发消息问我。
比如:
int foo(char a[10]);
在这种情况下这样的声明与
int foo(char a[]);
int foo(char * a);
是等价的,就是说这种情况下,就算你写的是数组的形式,编译器实际处理的时候也当指针来处理(注意指针是变量,形参也是变量,二者刚好对应)。所以在函数foo内部,你对a进行++, --, +=,=之类的带赋值的操作是完全合法的,因为此时a就是一个指针,不是数组名,当你往函数foo里面传入一个已经事先声明的数组的首地址时候,指针a里面的值就是你这个已经声明的数组的首地址,这样你在foo里面就可以对你那个数组进行操作,正是因为C有这个传地址的优点,所以省略了很多不必要的拷贝工作,试想如果没有这个传地址,你传一个有几万个元素的数组进去,那拷贝工作是相当可观的。这样,你该明白了int main(int argc, char ** argv);里面为什么可以对argv进行++操作了,既然“main函数的第二个形参是一个指向字符串的指针数组”,argv出现在函数声明中,所以它实际上是一个指针,它并不是“一个指向字符串的指针数组”,而是一个可以获取“一个指向字符串的指针数组”的首地址值的变量。楼主,请结合我前面的讲解,仔细体会我前面这句话的意思。国内的教材不知道怎么写的,把别人越讲越晕。如果不明白,尽管发消息问我。
展开全部
1、数组的首地址,在同一计算机上,正常运行的情况下,这个地址是不会变的。
2、数组的首地址,在不同的计算机,不同的系统上,一般情况下这个地址会变的。
3、现代操作系统的内存管理使用的是虚拟内存技术,一般来说,习惯性的讲内存看作是一个大的字节数组,每一个字节都有一个内存地址,本身虚拟内存地址的变化在同一台计算机上基本不大,但是实际的物理内存地址,变化肯定是很大的。问题中所说的数组的首地址,本质上是虚拟内存地址,因此才有1和2中的描述。
2、数组的首地址,在不同的计算机,不同的系统上,一般情况下这个地址会变的。
3、现代操作系统的内存管理使用的是虚拟内存技术,一般来说,习惯性的讲内存看作是一个大的字节数组,每一个字节都有一个内存地址,本身虚拟内存地址的变化在同一台计算机上基本不大,但是实际的物理内存地址,变化肯定是很大的。问题中所说的数组的首地址,本质上是虚拟内存地址,因此才有1和2中的描述。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
数组有两种定义方法:
1.int a[];
2.int *a;
这两种差不多是等价的,也就是说,2中的a=1中的a,因为a就是一个地址。
比如在1中访问元素是a[5];
那么在2中访问元素是*(a+5);
这两种访问是等价的!
要好好理解指针的定义才能弄明白,因为要记住,数组名就是一个指针,指针的内容是数组第一个元素的地址!
你说的argv++在这里是a++,就是相当于在数组中的a[i++];
也就是说a[i++]=*(a++),可以上机实践一下
1.int a[];
2.int *a;
这两种差不多是等价的,也就是说,2中的a=1中的a,因为a就是一个地址。
比如在1中访问元素是a[5];
那么在2中访问元素是*(a+5);
这两种访问是等价的!
要好好理解指针的定义才能弄明白,因为要记住,数组名就是一个指针,指针的内容是数组第一个元素的地址!
你说的argv++在这里是a++,就是相当于在数组中的a[i++];
也就是说a[i++]=*(a++),可以上机实践一下
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
任何数组的数组名 都可以进行 argv++ 的操作吧
数组名代表的 是一个在数组初始化时指向数组首地址的一个指针
argv++ 不过是把这个指针指向的地址 移向内存中的下一个地址
就这样而已
数组名代表的 是一个在数组初始化时指向数组首地址的一个指针
argv++ 不过是把这个指针指向的地址 移向内存中的下一个地址
就这样而已
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
数组名不能改变(是指针常量)
argv不是数组名。比如声明为如下形式 char * argv[],argv是指向字符串数组的指针。
argv不是数组名。比如声明为如下形式 char * argv[],argv是指向字符串数组的指针。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询