数组作为实参,指针作为形参,传递的就只是地址。...write,u16 Num) { uint16_t i; for(i=0;i<Num;i++) { write[i]=read[i]; } } 这样传递下来,buffer数组的值为...*write,u16 Num) { uint16_t i; for(i=0;i<Num;i++) { write[i]=read[i]; } } 这样的buffer数组的值为...由于buffer作为实参是8位数组,因此数组内储存的实际值为{0x01,0x01,0x02,0x02,0,0}。 可以看出数组指针看出仅仅是传递了地址,然后在函数内部按照函数自己的规则进行运算。
前言 C语言函数里最常用就是指针传参和返回地址,特别是字符串处理中,经常需要封装各种功能函数完成数据处理,并且C语言标准库里也提供了string.h 头文件,里面包含了很多字符串处理函数;这些函数的参数和返回值几乎都是指针类型...这篇文章就介绍如何使用指针作为函数参数、并且使用指针作为函数返回值。 下面通过几个示例代码来演示用法。 2....c=*a; *a=*b; *b=c; } //return语句只能返回一个值 //如果函数想返回多个值,可以使用指针(形参)实现。...注意: 从大到小或者小到大排序可以通过函数形参区分。...='\0'){} return str-p-1; } /* 函数功能: 实现字符串排序.支持从小到大或者大到小 函数形参: char *p 将要排序的字符串 char flag 选择排序方式
数组元素的值做实参 数组元素作为实参时,将数组元素的值传递给形参,传递的方向是从实参向形参的单向值传递。 例:编写函数求一维数组的最大值。...a:b; } 数组名称做形参 当数组作为形参时,虽然形式上还是数组,比如void sort(int arr[ ]),但是并不意味着真正建立了一个包含和实参数组大小相同的数组,在调用函数时也不对它分配存储单元...,只是用array[ ]这样的数组形式表示array是一维数组名,来接收实参传来的地址,因此array中的方括号的数值并无实际作用,编译器对数组维度进行忽略。...,向形参变量传递的是数组元素的值 用数组名做函数实参时,向形参传递的是数组首元素的地址。...数组名作为函数实参传递时,函数定义处作为接收参数的数组类型形参既可以指定长度也可以不指定长度。 数组元素作为函数实参传递时,数组元素类型必须与形参数据类型一致 。
文章目录 一、一维数组形参退化 二、二维数组形参退化 三、数组形参等价关系 一、一维数组形参退化 ---- C 中将 一维数组 作为参数 , 传递到函数中 , 该 一维数组 会退化为 指针 ; 将 int...中 , 如果将整个数组作为形参 , 需要拷贝整个数组的内容 , 如果数组有 1000 个元素 , 需要拷贝 4000 字节 , 这样效率就很低了 ; 如果只需要拷贝数组地址 , 这个地址存放在指针变量中...(int array[]) { } int *array void fun(int *array) { } 二、二维数组形参退化 ---- 二维数组 作为 函数形参 , 也会退化为指针 ; 将 二维数组...也是 指针 , 则形参为 二级指针 ; 实参为 二维数组 int array[10][20] , 等效的 形参为 一级指针 int (*array)[20] ; 二维数组 的 数组的元素 是 一维数组...; 外围数组 ( 第二维 ) 退化为 指针 , 指针 指向的元素 是 一维数组 , 则形参为 指向 一维数组 的指针 , 每个一维数组有 20 个元素 ;
即计算数组的大小,但是结果却是始料未及的。 出现这样的结果其原因就是在函数中,当数组作为形式参数进行传参时,其意义发生了变化。将其解析为一个指针,而指针的大小为四个字节。...此时将数组作为一个指针类型进行计算。
文章目录 导引 指针函数 指针函数定义 指针函数的三种写法 代码示例 函数指针 定义 代码示例 函数指针和指针函数区别 定义不同 写法不同 用法不同 导引 函数指针和指针函数,在学习 C 语言的时候遇到这两个东西简直头疼...,当然还有更头疼的,比如什么函数指针函数、指针函数指针、数组指针、指针数组、函数指针数组等等,描述越长其定义就越复杂,当然理解起来就越难,特别是刚开始学习这门语言的童鞋,估计碰到这些东西就已经要崩溃了,
C++问题: 使用函数调用,排序string字符串数组从小到大,没有使用指针和引用,为什么实参也会改变?...{ if(s[j + 1] < s[j]) { temp = s[j]; s[j] = s[j+1]; s[j+1] = temp; } } } } 改变的值是实参的值,也就是说实参对形参传的是地址...,此时形参与实参为同一个地址,形参在改变形参也会改变,所以string类与数组做形参时一样,string类的形参是一个指针,接受的是字符串首个字符地址,其中数组类型在存贮数据是连续线性存贮的,而string...类在存贮字符串数组则是存贮每个字符串首字母的地址,比如a[3] = {"I","love", "c++"}中a[2]为第一个字符串的地址,也就是love种l的地址,这样一来string类字符串数组的每一个字符串长度没有限制...这是关于C++中string类比C语言中数组类型的改进。
不带形参的main函数一般写成: int main() 或 int main(void) 表示mian函数没有参数,调用mian函数时不需要给出实参。...而main函数有形参的形式: int main( int argc, char** argv) int main( int argc, char *argv[]) 我是这样理解这两种方式,其中第一种方式...第二种 *argv[]是指针数组,由于[]的优先级比*高,所以argv[]是一个数组,而数组名其实代表的是首地址,还是一个地址。所以这两种方法没有什么区别。
实参是程序中已经分配了内存空间的参数,它可以被赋予一个具体的值,比如常数、数组、地址(指针),也可以是一个变量名、数组名或表达式,当然也包括指针变量。...形参则是你在写一个被调函数时,为了说明用到的自变量的类型、要进行什么操作而定义的,在调用函数前它不会被分配内存空间,更不会被赋予具体的值。...调用函数时,形参会被分配一个新的内存空间,实参的值就会被“复制”进去,让它在被调函数中参与运算。而实参本身不参与这个运算,它仅仅起到一个传递值的作用(不过在C++中可以用&改变实参的值)。
Java静态方法和实例方法 java中的数组作为形参传入 Java虚拟机 启动一个Java程序的时候,会诞生一个虚拟机实例,当程序关闭退出时,该实例会消失。...如果一个机器上运行着三个Java程序,即有三个Java虚拟机实例 Java虚拟机会调用某个初始类的main()方法运行一个Java程序,此方法将会作为程序的初始线程启动,任何线程都是由主线程启动的。...对象中会有一个指向方法区的指针,用来把堆中new出的对象和方法区的类和静态变量连接起来 堆有两个部分,一个句柄池,一个对象池。...在Java中和js一个样子 数组即对象,对象即数组 数组是储存在堆中的 所以,在调用方法的时候传入数组即传入了对象,这个时候(由于java中只有一个堆,用来储存对象)在方法中对数组的操作,即操作了堆中对象的操作...当方法调用完成以后,会弹出帧,销毁内容 关于方法调用传入数组和变量的的区别,数组,是一个对象,指向堆中的一块储存地址,变量,属于当前方法帧中的方法栈,调用的时候会直接压栈,调用完成以后会执行出栈操作。
同时,把元素外层*()剥去就代表地址。因此只写元素。 最后有总结。 二维数组作函数参数,依我看来,至少可以分成三种。 事先,在main函数中 int a[m][n]; 好了,进入主题。...第一种形参为二维数组 声明 void function(int a[m][n]);//函数声明 void function(int a[][n]);//不论多少维数组,第一维都可省略。...第二种形参为数组指针 (其实只是 声明定义 与第一种不同,其他一样) 声明 void function(int (*a)[n]); //不是(int *a[n])(指针数组) ,而是(int (*a)...第三种形参为二级指针 声明 void function(int **a,int n);n表示第二维数组长度,即列宽 调用 function( (int **)a,int n);//实参不能为数组名!...同时,把元素外层()剥去就代表地址。 喜欢就为我点赞,评论加收藏。
int a = 10; int *p=&a;//相当于int *p; p=&a; 单独 p 的值表示指向a的地址 *p = 5; //把p指向的地址,解引用(拆开编号&a地址的盒子,里面a的值赋值为5)...10; test(b); cout << “b的值:” << b << “\n” << “b的地址:” << &b << “\n”; } 相当于变量的别名,函数内后续的任何改变都会影响原变量 数组形参...当要使用数组作为函数形参时,因为一个数组不能使用另外一个数组初始化,也不能将一个数组赋值给另外一个数组,而在“1.1 非引用形参”中提到要用实参的副本来初始化形参,所以实参为数组时,不能直接传递给形参...FindMax(int array[10]); 虽然不能直接传递数组,但是函数的形参可以写成数组的形式。...此时,调用该函数是的实参数组被编译器自动转换为指针,也就是说,以上三种定义是等价的,其参数类型都是int*。 调用该函数时,直接将数组名称作为实参即可。
文章目录 一、多维数组做函数形参退化为指针过程 1、使用 int array[2][3] 作函数参数 2、使用 int array[][3] 作函数参数 3、使用 int (*array)[3] 作函数参数...一、多维数组做函数形参退化为指针过程 ---- 一维数组 作为 函数参数时 , 会退化为指针 ; 解决方案是 传入 数组首地址 和 数组元素个数 ; 如果 多维数组 作为 函数参数时 , 也存在退化问题...; 1、使用 int array[2][3] 作函数参数 使用 int array[2][3] 作为函数参数 , 可以完整打印出二维数组中的值 ; #include #include...// 命令行不要退出 system("pause"); return 0; } 执行结果 : 2、使用 int array[][3] 作函数参数 使用 int array[][3] 作为函数参数...命令行不要退出 system("pause"); return 0; } 执行结果 : 3、使用 int (*array)[3] 作函数参数 使用 int (*array)[3] 作为函数参数
01数组元素作函数实参 1、数组元素可以用作函数实参,不能用作形参。 2、在用数组元素作函数实参时,把实参的值传给形参,是“值传递”方式。 3、数据传递的方向是从实参传到形参,单向传递。...02 数组名作函数参数 1、除了可以用数组元素作为函数参数外,还可以用数组名作函数参数。...2、用数组元素作实参时,向形参变量传递的是数组元素的值,而用数组名作函数实参时,向形参传递的是数组首元素的地址。 3、用数组名作函数参数,应该在主调函数和被调函数分别定义数组。...4、实参数组与形参数组类型应一致,如不一致,结构出错。 5、形参数组可以不指定大小,在定义数组时在数组名后面跟一个指针变量,用来接收一个地址。...C语言 | 统计捐款人数及人均捐款数 更多案例可以go公众号:C语言入门到精通
文章目录 一、二级指针 二、完整代码示例 一、二级指针 ---- 指针 作为 函数输入 : 调用者 负责 分配内存 ; 指针 作为 函数输出 : 函数 负责 分配内存 , 一般 传入二级指针 , 函数负责生成内存...一级指针 指向 在 函数中 分配好内存 ; 如果要在 函数中 分配内存 , 则 需要 传入二级指针 , 在函数内部调用 malloc 函数 , 分配内存 , 返回一个 一级指针 变量 ; 令 二级指针 形参
指针数组 1.1 基本概念 指针数组是指一个数组,其中的每个元素都是指针。 这意味着数组中的每个元素都存储一个地址,该地址指向内存中的某个位置。...指针数组的声明形式为: data_type *array_name[size]; //示例: int *p[10];//该指针数组包含10个整型地址 1.2 简单示例 以下是一个简单的示例,演示了如何声明和使用指针数组...指针数组做main形参 2.1 int main(int argc, char *argv[]); 指针数组的一个重要应用是做main函数的形参。...return 0; } /*输出 Number of command line arguments: 1 Argument 0: D:\Program Files\code\CC++程序集合\c\...【谭浩强】C语言自学\output\mytest.exe */
本文链接:https://blog.csdn.net/solaraceboy/article/details/103187291 C 语言中关于通过形参传递数组的长度计算的一些思考 一 背景 学习 C...语言的过程中,计算数组的长度经常会碰到。...在字符型的数组中我们可以使用 strlen() 来获取当前数组的长度,对于其他类型的数组,这个方法就不适用了。由于经常会遇到计算数组长度的问题,经过思考,考虑通过一个函数来实现数组长度的计算。...思路是这样的:通过形参将数组传递给长度计算函数,长度计算函数计算完成之后返回数组长度。但是在实际实践过程中遇到了问题,请继续往下看!...length; } 执行结果: The length of this array is: 2 The length of this array is: 5 三 结果分析及总结 3.1 第一个结果,通过形参传递给数组长度计算函数来计算数组长度
数组元素作函数实参 数组元素就是变量,它与普通变量并无区别。因此它作为函数实参使用与普通变量是完全相同的, 在发生函数调用时,把作为实参的数组元素的值传递给形参,实现单向的值传送。...除了可以用数组元素作为函数参数外,还可以用数组名作函数参数(包括实参和形参)。...用数组名作函数参数时,则要求形参和相对应的实参都必须是类型相同的数组, 都必须有明确的数组说明,当形参和实参二者不一致时,即会发生错误。...在用数组名作函数参数时,不是进行值的传送,是把实参数组的首地址赋子形参数组名, 而不是把实参数组的每一个元素的值都赋予形参数组的各个元素。...用多维数组名作为函数参数传递的是数组首元素的地址,要求形参是相同类型的同维数组。 这里,形参是二维数组时,第二维的大小(长度)必须指明,而第一维的大小(长度)可以指明,也可以不指明。
一:数组元素作为函数的实参 数组元素就是变量,与普通变量没有区别,将数组元素传送给形参,实现单向的值传递。...:%d",m); } 二:数组名作为函数的实参 实质是地址的传递,将数组的首地址传给形参,形参和实参共用同一存储空间,形参的变化就是实参的变化。...:"); for(int i = 0;i < 10; i ++){ scanf("%d",&a[i]); } printf("排序后的数组顺序是:"); sort(a,10); for(int...i = 0; i < 10; i++){ printf("%d ",a[i]); } } 三:二维数组名作为函数参数 第一维的大小可以不指定,第二维的大小必须指定。...实参传送的是二维数组的首地址,使得二维数组a与b共用同一存储单元,即a[0][0]与b[0][0]共用同一存储单元,a[0][1]与b[0][1]共用同一存储单元。
领取专属 10元无门槛券
手把手带您无忧上云