C: 数组形参

知识这个东西,真是知道的越多就不知道的越多,C/C++这塘水得多深啊,哈哈。
看下面3个片段:
<一>





1 void fun(char
a[100]) {





2         fprintf(stderr, "%s\n", a);





3 }





4  





5 int main(void) {





6         char
aa[200] = "abcdef";





7         fun(aa);





8 }

<二>





1 void fun(char
a[]) {





2         fprintf(stderr, "%s\n", a);





3 }





4  





5 int main(void) {





6         char
aa[200] = "abcdef";





7         fun(aa);





8 }

<三>





1 void fun(char* a) {





2         fprintf(stderr, "%s\n", a);





3 }





4  





5 int main(void) {





6         char
aa[200] = "abcdef";





7         fun(aa);





8 }

以上三个片段的输出其实是一样的:

abcdef

  • fun(char
    a[100]):实际上这里数组长度100会被编译器忽略,唯一可能起的作用是提示调用者这里应该传入一个长度为100的数组,但这种提示也是毫无约束性的。

  • fun(char
    a[]):这里a[]的作用是可以提示调用者这里处理的是一个数组而并不是char*,但是编译器还是会将a当作一个char*来处理,也就是说如果你在fun()函数中测试sizeof(a)的话,你得到的是一个指针的长度(在32位机器上一般是4)。

  • fun(char *a):这种形式应该是普通青年最常用的方式了吧……^_^,一般还会加一个数组长度参数len 。

时间: 2024-12-20 11:55:28

C: 数组形参的相关文章

数组形参

数组的两个特殊性质对我们定义和使用作用在数组上的函数有影响,这两个性质分别是:不允许拷贝数组以及使用数组时(通常)会将其转换成指针.因为不能拷贝数组,所以我们无法以值传递的方式使用数组参数.因为数组会被转换成指针,所以当我们为函数传递一个数组时,实际上传递的是指向数组首元素的指针. 尽管不能以值传递的方式传递数组,但是我们可以把形参写成类似数组的形式: //尽管形式不同,但这三个print函数时等价的 //每个函数都有一个const int*类型的形参 void print(const int

参数传递:传值参数,指针形参,传引用参数,const形参和实参,数组形参,main:处理命令行选项,含有可变形参的函数

重点: 1.每次调用函数时都会重新创建它的形参,并用传入的实参对形参进行初始化. NOTE: 形参初始化的机理与变量初始化一样. 2.形参的类型决定了形参和实参交互的方式. (引用->绑定,非引用->拷贝) 3.实参分为:被引用传递(引用形参是实参的别名),被值传递(实参形参是两个相互独立的对象). 4.传值参数:函数对形参做的所有操作都不会影响实参. 5.指针形参:指针的行为和其他非引用类型一样,当执行指针拷贝操作时,拷贝的是指针的值.拷贝后,两个指针是不同的指针. NOTE: C程序员常常

C专家编程之为什么C语言把数组形参当做指针:数组/指针实参

#include<stdio.h> void print_array_test(char ca[]) { printf("ca : %s\n",ca); printf("&ca : %s\n",&ca); printf("&(ca[0]) : %s\n",&(ca[0])); printf("&(ca[1]) : %s\n",&(ca[1])); printf(&qu

c++之数组形参

1.问题,最近看项目log模块,_log模板函数中的一个参数竟然看蒙x了.函数原形是这样: template<size_t size>void _Log(char (&strDest)[size], const char *scetion, const char *key, const char *msg, va_list &parm); 对!就是 char (&strDest)[size]没有看懂.这个传进来的是个字符串数组. 2.翻开c++圣经<c++prim

C语言 数组形参

#include<stdio.h> #define M 80 void proc(int *w,int p,int n) { int i,j,t,k; for(i=p;i<=n-1;i++) { t = w[n-1];  //保存最后一个数 for(j = n-2;j >= 0 ;j--) w[j+1] = w[j];   //所有数后移一位 w[0] = t;    //将最后一个数的数值赋给第一位 } } void main() { int arr[M] = {1,2,3,4,

关于二维数组传参做形参(转)

二维数组的存储方式是和一维数组没什么区别,但是用二维数组做参数,它的形参该怎样写?要注意的是:函数中的形参其实就相当于一个声明,并不产生内存分配,形参的目的就是要让编译器知道函数参数的数据类型. 正确的是:void Func(int array[3][10]); void Func(int array[][10]);可以省略第一维的大小 错误的是void Func(int array[][].这样的用法只能在初始化时可以用);这样写也是错误:void Func(const int m,const

附录一 再论指针和数组

附录一 附录一 再论指针和数组 再论指针和数组 [email protected]:Kevin-Dfg/[email protected]:Kevin-Dfg/Data-Structures-and-Algorithm-Analysis-in-C.git 预习检查 链表单元有哪几个部分组成 如何申请链表单元,及释放链表单元 实现单链表插入的基本语法 简述一下快速排序基本理论要点 [email protected]:Kevin-Dfg/[email protected]:Kevin-Dfg/Dat

C++ 中数组做参数的分析

C++ 中数组做参数的分析 1.数组降价问题? "数组引用"以避免"数组降阶",数组降阶是个讨厌的事,这在C语言中是个无法解决的问题,先看一段代码,了解什么是"数组降阶" 1 #include <IOSTREAM> 2 using namespace std; 3 4 void Test( char array[20] ) 5 { 6 cout << sizeof(array) << endl; // 输出 4

关于函数形参的一些讨论

形参的初始化与变量的初始化一样:如果形参具有非引用类型,则复制实参的值,如果形参为引用类型,则它只是实参的别名. 非引用形参: 普通的非引用类型的参数通过复制对应的实参实现初始化.当用实参副本初始化形参时,函数并没有访问调用所传递的实参本身,因此不会修改实参的值. while 循环体虽然修改了 v1 与 v2 的值,但这些变化仅限于局部参数,而对调用 gcd 函数使用的实参没有任何影响.于是,如果有函数调用gcd(i, j),i 与 j 的值不受 gcd 内执行的赋值操作的影响. #includ