【进阶指针一】字符指针&指针数组&数组指针 https://blog.csdn.net/qq_64428099/article/details/125011487 目录 1.数组传参 1-2 二维数组传参... 2 指针传参 2-1 一级指针传参 2-2 二级指针传参 2-3 关于传&arr和arr 3 函数指针 3-1 函数指针的引入 3-2 函数指针的脱裤子放屁使用【先见一见基本操作】 3-3 试图看懂大佬写的代码... 4 函数指针数组 4-1函数指针数组的引入和基本使用 4-2 函数指针数组的妙用 ---- 1.数组传参 1-1一维数组传参 正向:实参给定,猜猜看形参可以怎么写?...2 指针传参 反向:形参给定,猜猜看实参可以怎么写?...// arr是二维数组数组名,表示的是一维数组的地址 return 0; } 2-3 关于传&arr和arr 2-3-1 这里以二维数组为例,讲一讲实参和形参的匹配问题 void test1
在C中,我们只了解到有两种传参方式,一种是值传递,另外一种是传递指针,一般情况下我们选择使用指针传递参数。在C++中,又新增了一种传参方式,那就是引用(type &),引用传参给我们带来了更好的体验。...2、指针传递 指针则解决了上面的两个问题,首先指针在32位系统下(64位系统是8字节)只有4个字节,无论数据多大,只要你将其指针传递给传输在压栈过程中只需要压一个4个字节的指针。...#include using namespace std; // 值传递,无法交换变量的值 // 另外注意:值传递和引用传递函数重载时会出现二义性 // 程序不知道该重载哪个函数来使用。...int tmp = ra; ra = rb; rb = tmp; } int main(int argc, char* argv[]) { int x = 10; int y = 20; // 传指针...// swap(&x, &y); // 传引用 swap(x, y); cout << x << “–” << y << endl; getchar(); return 0; }
前面说到,将指针作为参数传入,在函数内部对指针进行修改,函数结束后指针的修改将被保留。 因为指针传参代表着地址传参。 本篇解惑:如何让对指针参数的修改不被保存。...原因很简单,pNode->next也是一个映射地址,这句话的意思就是用一个新的地址映射,顶替掉那个旧的,使得指针pNode指向一块新的地址,和the_head失去联系。
[]的优先级要高于*号的,所以必须加上()来保证p先和*结合。 int *p1[10];//指针数组,p1先和[10]结合,说明p1是一个数组。...四、二维数组传参,形参写二维数组 1、为什么一维数组传参,形参可以是数组,也可以是指针?...1.写成数组更加直观,为了方便理解 2.写成指针传参是因为数组传参,传递的是数组的第一个元素的地址 二维数组传参,形参写成数组也是可以的,非常直观,容易理解 2、形参能写成指针吗?...return 0; } 二维数组传参 void Print(int (*arr)[5], int r, int c) { int i = 0; for (i = 0; i < r; i++)//...*)[5],那就意味着二维数组传参本质上也是传递了地址,传递的第一行这个一位数组的地址,那么形参可以写成数组指针的形式 五、函数指针变量 函数指针变量的创建 函数指针用来存放函数的地址 1、回调函数
这是道哥的第013篇原创 前言 今天同事问了一个问题:在函数参数中传递指针的指针,很常用的一个场景,重新梳理一下记录于此,以后如果有类似的问题直接发这篇小总结就可以了。...分析原因 我们可以把char*类型的指针看成一个遥控器,如果给这个指针赋值,就相当于把这个遥控器与一个设备进行绑定,可以通过遥控器来控制这个设备。...执行do_work(pData, 128); 这里传递的参数是pData本身,所以进入void do_work(char *p, int size)函数之后,实参pData的内容就赋值给形参p,所以指针...执行do_malloc(&pData, 128); 把pData指针的地址作为实参进行传递,因为pData本身就是一个指针,加上取地址符&,就是指针的指针(二级指针),因此do_malloc函数的第一个参数就要定义成...p此时是一个二级指针,参数赋值之后,p里面的内容就变成了pData这个指针变量的地址,也就是说p指向了pData这个变量。
在一次稀疏矩阵压缩算法中,为了保证压缩函数可复用性,使用了void** 作为压缩形参,结果二维数组传入一直无法获取到内容。...结果出现的方案如下 方法1 方法2: 数组指针 或者是 二级指针 结果相同 int ** arr; 上述两种情况指针步长都会是一个int* 的大小,也就是4个字节 ,这个可以从第二章图,13630500
1、一维数组传参的本质 数组传参是指在函数调用时将数组作为参数传递给函数。...void test(int arr[])可以写为void test(int* arr) 注意: 一维数组传参的时候,形参可以写成数组的方式,主要是为了方便理解,形参也可以写成指针变量的方式 如果我们想要在函数内部获取数组元素的个数...从上图中,我们可以看到二维数组传参传递的也是数组名,数组名是什么呢? 数组名是数组首元素的地址,所以二维数组实参传递的是地址,既然传递的是地址,那么形参也就可以使用指针来接收。...二维数组传参传递的不是二维数组,而是二维数组首元素的地址,也就是第一行的地址,所以形参的部分要拿数组指针来接收。...3、总结: 数组传参传递的都是地址,所以形参都可以使用指针来接收 一位数组传参传递的是首元素地址,使用(类型)指针来接收, 二维数组传参传递的是一维数组的地址,使用数组指针来接收 本篇文章到这里就结束了
一、指针与函数传参: 1、普通变量作为函数形参: (1)函数传参时,普通变量作为参数时,形参和实参名字可以相同也可以不 同,实际上都是用实参来替代相对应的形参的。...因为传参时是传值,所以这两个没区别)。所以在子函数内部,传进来的数组名就等于是一个指向数组首元素首地址的指针。...(2)在子函数内传参得到的数组首元素首地址,和外面得到的数组首元素首地址的值是相同的。...因为数组名做形参传递的实际只是个指针,根本没有数组长度这个信息。...: (1)和数组作为函数形参是一样的.这就好像指针方式访问数组元素和数组方式访问数组元素的结果一样是一样的。
不带形参的main函数一般写成: int main() 或 int main(void) 表示mian函数没有参数,调用mian函数时不需要给出实参。...而main函数有形参的形式: int main( int argc, char** argv) int main( int argc, char *argv[]) 我是这样理解这两种方式,其中第一种方式...**argv是指针的指针,指针指向变量,指针是一个地址,所以*argv是一个地址。...第二种 *argv[]是指针数组,由于[]的优先级比*高,所以argv[]是一个数组,而数组名其实代表的是首地址,还是一个地址。所以这两种方法没有什么区别。
一、数组指针 初学C语言的朋友对数组指针这指针数组感到迷惑,分不清,包括我自己,其实是对概念的不清晰以及对数组和指针这两个概念理解的不够深入,下面谈谈我的理解。...数组指针,是一个指针而不是数组。 这个指针具有指向整个数组的能力,保存这个数组的其实地址。...是数组指针变量 二、指针数组 指针数组,是一个数组,而不是指针。...,这个指针指向.rodata对应的常量字符串 指针数组的应用 完整的main函数原型,int main(int arc,char* argv[],char* envp[]) 其中,两个数组分别保存命令行参数和环境变量...为了提高程序执行的效率,C语言不做数组下标的安全性检查。如果进行了检查当数组数据量非常大时候会显著减低程序的效率,在安全性和高效率之间,权衡利弊之下。
上一篇写道路由跳转 这里写一写路由跳转的时候是如何进行路由传参的 首页start的传参问题 开始页引进ref 先定义几个参数,然后通过路由的形式把这几个参数传递到另一个路由 let name...params传参 router.push({ path: "/home", params: { name: name.value,...path和name都可以 params传参只能用name 图片.png params传入的参数不会在地址栏中显示,刷新之后就没有了 Start.vue ...router.push({ // path: "/home", //push里面还可以传入name name是路由名字 // query传参...path和name都可以 // params传参只能用name name: "Home", params: { name: name.value
初遇二维数组作函数参数,宛如自己化身为了大头儿子。很头大。 不禁大声呐喊:该怎么声明定义,该怎么调用,又该怎么函数中操作元素和地址? 在此,我要拨开这些问题的一些迷雾。...第一种形参为二维数组 声明 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);//实参不能为数组名!...(都是指针) 调用(一对一,二对二) 数组指针,二维数组就写一级指针即 数组名.
数组作为实参,指针作为形参,传递的就只是地址。...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}。 可以看出数组指针看出仅仅是传递了地址,然后在函数内部按照函数自己的规则进行运算。
即计算数组的大小,但是结果却是始料未及的。 出现这样的结果其原因就是在函数中,当数组作为形式参数进行传参时,其意义发生了变化。将其解析为一个指针,而指针的大小为四个字节。...此时将数组作为一个指针类型进行计算。
指针数组 1.1 基本概念 指针数组是指一个数组,其中的每个元素都是指针。 这意味着数组中的每个元素都存储一个地址,该地址指向内存中的某个位置。...指针数组的声明形式为: data_type *array_name[size]; //示例: int *p[10];//该指针数组包含10个整型地址 1.2 简单示例 以下是一个简单的示例,演示了如何声明和使用指针数组...*intArray[3]; // 声明一个包含3个整型指针的数组 // 将指针指向整型变量 intArray[0] = &num1; intArray[1] = &num2;...指针数组做main形参 2.1 int main(int argc, char *argv[]); 指针数组的一个重要应用是做main函数的形参。...2.2 简单示例 下面例子中,argc 表示命令行参数的数量,而 argv 是一个指针数组,其中每个元素都是一个指向字符串的指针。程序通过循环遍历 argv 数组,输出每个命令行参数的内容。
当我们使用指针传参的时候,会从实参拷贝一份对象到形参,二者是不同的指针,但是指向同一块地址。 如果在被调用函数中对参数指针进行重新指向,则不会影响到调用函数中的实参。
&arr[0]和arr都是首元素的地址,+1就是跳过一个元素 4.因为&arr是数组的地址,+1的操作是跳过整个数组的 四.使用指针访问数组 1.因为数组在内存中是连续存放的。...数组传参的时候形参是不会创建数组的,实际上传的是首元素的地址,发生了数组降级 void test(int arr[]) //int *arr { int sz = sizeof(arr) / sizeof...//test(arr);//这里的数组名就是数组首元素地址 Print(arr,sz); return 0; } 六、传址调用和传值调用 传值调用:传的是变量,传值调用 int Add...//数组名是数组首元素的地址 printf("%zd\n", len); return 0; } 6.2为什么有传址和传值两种调用方式 因为有一些问题是不使用指针无法解决的!!!...传值调用函数时,函数的实参传给形参,形参是实参的一份拷贝 形参有自己独立的空间,对实参的修改不会影响实参!!!
1.前言好了,经过上篇文章的介绍,给大家详细的介绍了云函数的基本使用,以及为什么要使用云函数,那么接下来我们就来看看云函数的传参和调试。...云函数传参async onCloudFnParamTap() { const...点击本地调试,会弹一个对话框点击是,就是安装所需要的依赖库:然后观察微信小程序的终端就会去下载依赖:下载完毕之后本地调试界面就成了如下图所示的样子:这个时候就会浏览器差不多咯,然后我们再次来点击调用云函数传参按钮来看看效果...本地调试输出内容:可以看到,这个时候就有我们想要的结果了,那么这个时候关于云函数的传参和调试就介绍完毕了。本篇文章内容介绍到这就结束了,我们下期再见,感谢大家的观看,谢谢大家。...您的每一个动作都是对我创作的最大鼓励和支持。谢谢您的阅读和陪伴!感谢您的支持,我会继续努力的!我正在参与2024腾讯技术创作特训营第五期有奖征文,快来和我瓜分大奖!
原因:在func函数调用过程中,形参和实参的传递使用了值传递方式,这种情况下,形参变量在函数体内发生了变化,在函数结束之后,形参变量随之释放,不能把变化的结果返回给实参。...因为引用不是对象,故无引用的数组,无指向引用的指针,无到引用的引用: int& a[5]; // 错误 int&* p; // 错误 int& &r; // 错误 所以修改函数int func...、传引用区别和联系 传值:实参拷贝传递给形参。...复制完毕后实参的地址和形参的地址没有任何联系,对实参形参地址的修改不会影响到实参, 但是对形参地址所指向对象的修改却直接反应在实参中,因为形参指向的对象就是形参的对象。...无论传值还是传指针,函数都会生成一个临时变量,但传引用时,不会生成临时变量, 传值时,只可以引用值而不可以改变值,但传值引用时,可以改变值, 传指针时,只可以改变指针所指的内容,不可以改变指针本身,但传指针引用时
原因:在func函数调用过程中,形参和实参的传递使用了值传递方式,这种情况下,形参变量在函数体内发生了变化,在函数结束之后,形参变量随之释放,不能把变化的结果返回给实参。...因为引用不是对象,故无引用的数组,无指向引用的指针,无到引用的引用: int& a[5]; // 错误 int&* p; // 错误 int& &r; // 错误 所以修改函数int func(...、传引用区别和联系 传值:实参拷贝传递给形参。...复制完毕后实参的地址和形参的地址没有任何联系,对实参形参地址的修改不会影响到实参, 但是对形参地址所指向对象的修改却直接反应在实参中,因为形参指向的对象就是形参的对象。...无论传值还是传指针,函数都会生成一个临时变量,但传引用时,不会生成临时变量, 传值时,只可以引用值而不可以改变值,但传值引用时,可以改变值, 传指针时,只可以改变指针所指的内容,不可以改变指针本身,但传指针引用时
领取专属 10元无门槛券
手把手带您无忧上云