c语言中矢量变量,C语言中参数向量argv问题

这篇博客探讨了C语言中关于argv参数在main函数中的特殊性,解释了数组名作为常量不能修改但可以作为左值操作的情况。文章提到了编译器在处理char*argv[]时的隐式转换,并通过例子展示了函数参数中数组的传递实际上是传递指针。还讨论了函数参数中数组与局部变量的区别,以及如何理解数组参数在函数调用时的行为。
摘要由CSDN通过智能技术生成

楼上蓝皮鼠 基本上都回答了,我就再啰嗦几句补充一点东西吧;-)

这问题其实挺有趣的,对于argv来说,既然定义成

char *argv[]

那不就是说明argv是一个指向字符串的指针数组,怎么也能左值操作?

我们知道数组名其实就是一个常量,是不能被直接修改的,这是它与指针一个最大的区别。

这里argv与arr最大的区别是一个是函数中的参数,一个是定义的局部变量。

一般可以从两个方面来理解这个问题。

一个方面,正如蓝皮鼠所说的,main函数的原型中argv其实是

char **argv

这样,对于定义成char * argv[]的参数,gcc在编译时会有一个隐式转换,因为这里这两者是是相容的,就算你定义成

char const * argv[]

对于argv来说,这个定义就不相容了。不过一般会有两个结果,要么编译器很严格直接报错,要么会给个警告信息,然后继续把它当成 char **argv 来用。

所以你直接对argv进行左值运行,代码可以被编译通过,就正常了。

另一方面,在C语言中,参数中的数组传递有些特殊。比如下面的代码:#include

int func(char *v[])

{

*++v;

printf("&v=%x\t v=%x\n",&v,v);

}

int main(int argc, char const* argv[])

{

char const* arr[]={"1","2","3"};

printf("&argv=%x\t argv=%x\n",&argv,argv);

printf("&argc=%x\t argc=%x\n",&argc,argc);

func(argv);

}

因为main函数是程序的入口函数,是被编译内部定义好的,所以可以再定义一个

int func(char *v[])

结果发现这个v仍然可以进行左值操作。

上面说了参数中数组的传递有些特殊,因为在实际处理参数中的数组时,其实编译器是把它当成一个指针来处理。

比如你定义好一个数组

`

char arr2[10];`

假定有一个函数,其原型如下:

int func2(char p[]);

那么当以下调用发生时:

func2(arr2);

arr2的值会被复制一份到一个内部局部变量指针(堆栈或寄存器)中,这个指针指向arr2[0]的位置。这样arr就被传递进func2函数中了。

同时,这也是在定义函数的参数时,如果参数中有数组,我们一般不用在数组标记中间写上数组长度值的原因,因为没有意义,实际只是把数组的地址进行了传递。

比如:

'int func2(char arr[10])'

这就是我的理解和说明,希望对你有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值