首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【C语言】指针进阶之传值调用与传址调用

1.前言 学习指针的⽬的是使⽤指针解决问题,那什么问题,⾮指针不可呢? ✔在编程语言如C中,传值调用和传址调用是用来传递参数给函数的方法。...☞传址调用:这种方式则是将参数的地址传递给函数。这样做的目的是让函数能够直接访问到传入的参数,并且可以对这些地址指向的数据进行修改。...3.传址调用的举例说明 #include void Swap2(int*px, int*py) {  int tmp = 0;  tmp = *px;  *px = *py;...✔传址调⽤,可以让函数和主调函数之间建⽴真正的联系,在函数内部可以修改主调函数中的变量; 4.结论 所以未来函数中只是需要主调函数中的变量值来实现计算,就可以采⽤传值调⽤。...如果函数内部要修改主调函数中的变量的值,就需要传址调⽤。

14210
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    指针变量的传值和传址

    来源:公众号(c语言与cpp编程) 1 引言 举个例子:在func函数退出后,指针pInt所指的内容*pInt为 12 #include  //公众号:C语言与CPP编程 int func...因为引用不是对象,故无引用的数组,无指向引用的指针,无到引用的引用: int& a[5]; // 错误 int&* p;   // 错误 int& &r;   // 错误 所以修改函数int func(...、传引用区别和联系 传值:实参拷贝传递给形参。...无论传值还是传指针,函数都会生成一个临时变量,但传引用时,不会生成临时变量, 传值时,只可以引用值而不可以改变值,但传值引用时,可以改变值, 传指针时,只可以改变指针所指的内容,不可以改变指针本身,但传指针引用时...参考书籍《C陷阱与缺陷》

    2.8K40

    【C语言】传值调用与传址调用详解

    前言 在C语言的学习过程中,理解函数的参数传递方式是非常重要的概念。C语言支持两种常见的参数传递方式:传值调用(Call by Value)和传址调用(Call by Address)。...在C语言中,函数在被调用时会接收参数。参数传递是指在函数调用时,函数的输入数据(参数)如何从调用者传递到被调用的函数。传值调用和传址调用是两种常见的传递方式,它们的差别决定了函数能否改变传入参数的值。...C语言 传值调用 1. 什么是传值调用? 传值调用是C语言中最常见的函数参数传递方式。在这种方式下,函数接收到的是参数的副本。换句话说,函数在调用时并不会修改原始参数,而是对参数的副本进行操作。...传址调用的优缺点: 优点: 通过传递指针,可以直接修改外部变量,适用于需要在函数内修改外部变量的场景。 对于大数据(如数组、结构体等),传址调用比传值调用更高效,因为不需要复制大量的数据。...传址调用:当需要修改传入的参数,或者当参数较大(如数组、结构体等)时,传址调用更为高效。 小结 通过上述分析,我们深入探讨了C语言中两种常见的参数传递方式:传值调用和传址调用。

    11210

    【C语言进阶】指针数组 —— 数组指针

    鸽芷咕:个人主页 个人专栏:《C语言进阶篇》《C语言初阶篇》 ⛺️生活的理想,就是为了理想的生活!...文章目录 前言 指针数组 指针数组的定义 ✅ 指针数组的使用 如何访问存放在的指针数组里的数组元素 数组指针 数组指针的定义 &数组名VS数组名 数组指针的使用 数组指针(实例) 全篇总结...数组指针or指针数组是有明显不一样的下面我们就来看看 本期文章收录在《C语言初阶篇》,大家有兴趣可以看看呐! ⛺️ 欢迎铁汁们 ✔️ 点赞 收藏 ⭐留言 !...整形数组 是用来存放整形的数组 指针数组 自然是用来存放指针(地址)的数组 这样比较起来是不是就能快速的理解指针数组的概念! 指针数组的定义 数组我们已经知道整形数组,字符数组。...整形指针是用来存放整形地址的指针,那么数组指针是用来干什么呢? 所以数组指针是用来存放数组的地址的指针指针变量。

    16310

    【C语言函数调用详解】——传值调用&传址调用

    一.传值调用 什么是传值调用呢?顾名思义,传值调用就是直接将实参的值传递给形参。...这里就需要传址调用。 二.传址调用 那什么是传址调用呢?这里的“址”指的是地址。 传址调用是把函数外部创建变量的内存地址传递给函数参数的一种调用函数的方式。...那现在我们用传址调用的方法对上面的函数重新进行实现: #include //正确的版本 void Swap2(int* px, int* py) { int tmp = 0; tmp...); printf("Swap2::num1 = %d num2 = %d\n", num1, num2); return 0; } 对代码进行一下分析: 这次我们再来看看结果: 所以,传址调用可以让实参和形参建立起真正的联系...以上就是对函数调用的两种方式,传值调用和传址调用的介绍,欢迎大家指正,我们一起进步!!!

    92110

    C语言指针(二)数组指针云指针数组

    数组指针/指针数组 数组指针是: ❝指向数组的指针,它本质上还是一个指针,类比普通指针 ❞ 指针数组是: ❝一个存放指针的数组,本质上是数组,就如经常说的字符数组,整型数组一样 ❞ 2.1 数组的理解...arr[1] => *(&arr +1) 先让内存地址加下标,再通过指针获取到元素 ❞ 2.3 数组指针 数组指针就是指向数组第一个元素的指针,相信认真看了2.1和2.2的你能够很快理解 定义一个数组指针...int a[] = {1, 3, 5, 7}; // 一个数组 int (*p)[4] = &a; // 定义一个指针,指向数组的头元素 通过指针访问第二个数组元素: printf("访问数组的第二个元素...指针「数组」,顾名思义,他是个数组,就如经常说的字符数组,整型数组一样,只不过指针数组的定义方法和存储对象也有亿点点不一样。...定义一个指针数组(以整型为例) int *pArr[10]; // 定义一个指针数组 「要注意与数组指针的定义区别开」 数组指针的定义: int (*arrP)[10]; 一定要注意这个括号,这涉及到了

    1.3K00

    【C 语言】数组 ( 数组指针 | 数组指针定义 | 直接定义 数组指针 )

    文章目录 总结 一、直接定义 数组指针 二、完整代码示例 总结 int (*p)[3] = NULL; 一、直接定义 数组指针 ---- 直接定义 数组指针 , 首先 , 定义一个普通数组 ,...数组指针类型 变量 , 指针指向的数据类型为 int[3] 数组类型的变量 array2 ; ArrayPointer p = NULL; p = &array2; 验证上述 定义的数组指针...; } 使用 数组指针 , 打印数组元素内容 : // 使用 数组指针 访问数组中的值 for(i = 0; i < 3; i++) { printf("..., 数组元素是指针 (作为参考) char *array = {"12", "ab", "34"}; // 数组指针 , 使用指针变量指向数组 // 首先 , 定义一个普通数组..., 将 array2 变量地址赋值给该 数组指针类型 变量 // 指针指向的数据类型为 int[3] 数组类型的变量 array2 p = &array2; // 为数组赋值

    3.4K20

    c语言二维数组传参数_c语言数组传参

    第二种形参为数组指针 (其实只是 声明定义 与第一种不同,其他一样) 声明 void function(int (*a)[n]); //不是(int *a[n])(指针数组) ,而是(int (*a)...[n])(数组指针); // 缘由是 [] 的 优先级比 *的大 调用 function(a);//函数调用 实参同样直接写数组名!...n表示第二维数组长度,即列宽 //其他不被允许。由编译器的寻址方式决定。 总结 声明定义(分三种)。 二维数组,数组指针,二级指针。...(都是指针) 调用(一对一,二对二) 数组指针,二维数组就写一级指针即 数组名....二级指针就写二级指针即 (int**)数组名 在函数中操作元素(注意二级指针,只能用最后的方法) *(a[i] + j) //代表第 i 行 第 j 列 *( *(a+i) + j) //同上 *(

    2.8K10

    指针详解(const、指针运算、数组名的理解、传址调用和传值调用、一维数组的本质​)(一)

    ("%d", arr + i); } for (i = 0; i < sz; i++) { printf("%d ", *(arr + i)); } return 0; } 代码4 在C语言中使用...2.接下来,使用索引i对指针进行偏移。在C语言中,一个指针偏移n个元素就是移动指针到从起始位置开始的第n个元素。因此,通过偏移i个元素,你可以找到数组中第i个元素的位置。...//test(arr);//这里的数组名就是数组首元素地址 Print(arr,sz); return 0; } 六、传址调用和传值调用 传值调用:传的是变量,传值调用 int Add...//数组名是数组首元素的地址 printf("%zd\n", len); return 0; } 6.2为什么有传址和传值两种调用方式 因为有一些问题是不使用指针无法解决的!!!...此处不发生变化 Swap2(&a, &b);//传址调用 printf("交换后:a = %d b = %d\n", a, b); return 0; } int main() { int

    19610

    C语言函数传参:指针的指针

    这是道哥的第013篇原创 前言 今天同事问了一个问题:在函数参数中传递指针的指针,很常用的一个场景,重新梳理一下记录于此,以后如果有类似的问题直接发这篇小总结就可以了。...分析原因 我们可以把char*类型的指针看成一个遥控器,如果给这个指针赋值,就相当于把这个遥控器与一个设备进行绑定,可以通过遥控器来控制这个设备。...到这里就已经看到程序崩溃的原因了:虽然给指针p赋值了,但是实参pData中的内容一直为空,因此从do_malloc函数返回之后,pData仍然是一个空指针,所以就崩溃了。...执行do_malloc(&pData, 128); 把pData指针的地址作为实参进行传递,因为pData本身就是一个指针,加上取地址符&,就是指针的指针(二级指针),因此do_malloc函数的第一个参数就要定义成...p此时是一个二级指针,参数赋值之后,p里面的内容就变成了pData这个指针变量的地址,也就是说p指向了pData这个变量。

    2.1K20

    【C 语言】数组 ( 数组指针 | 数组指针定义 | 使用 数组指针类型 定义数组指针 )

    文章目录 总结 一、使用 数组指针类型 定义数组指针 二、完整代码示例 总结 // 首先 , 定义 数组指针类型 别名 typedef int(*ArrayPointer)[3];...// 然后 , 声明一个 数组指针类型 变量 ArrayPointer p = NULL; 一、使用 数组指针类型 定义数组指针 ---- 使用 数组指针类型 定义数组指针 , 首先 , 使用...typedef 定义一个数组指针类型 , typedef int(*ArrayPointer)[3]; 然后 , 定义一个普通数组 , 之后的 数组指针 指向该数组 , int array2...[3] = {0}; 最后 , 声明一个 数组指针类型 变量 , 将 array2 变量地址赋值给该 数组指针类型 变量 , 指针指向的数据类型为 int[3] 数组类型的变量 array2 ;..., 数组元素是指针 (作为参考) char *array = {"12", "ab", "34"}; // 数组指针 , 使用指针变量指向数组 // 使用 数组指针类型 定义数组指针

    3K10

    【C语言】C语言数组和指针

    ---- 友情提醒:本文可能是全csdn最详细的指针内容了,希望你能用心读下去 前言 接下来的讲解部分是指针的进阶,包含多种指针以及对应的数组,这部分章节对我们来说很重要,也是c语言中的重点模块儿,重要性不言而喻...(c/c++会把常量字符串储存到单独的一个内存区域中) 当这两个指针指向同一个常量字符串时,实际上就是指向同一块儿地址**(指针就是地址,地址就是指针)** 2.数组指针 2.1数组指针的定义 1.数组指针嘛...1.牢记以下重要的东西 很重要的知识要记住:我们要牢记,当传数组或指针到函数里面时,实际上传过去的是地址!...这个完全正确,用指针数组来接收二维数组的首行数组的地址 {} void test(int**arr) 二级指针接收是没必要,这里又不是传一级指针过来,人家就传个地址而已 {} int main() {...,他其实就是方便在当我们调用多个函数时,省去我们重复写调用函数的代码,如果有函数指针数组的话,我们直接访问函数指针数组的元素内容就可以了,然后向我们得到的函数名传相应的参数就可以了 下面给大家做一个功能较完整的函数指针数组的使用吧

    64.8K37

    【C语言】指针&&二级指针&&数组指针&&指针数组详解

    如何编址?...里了,但是,本质是把字符串 abcdef的首字符的地址放到了pstr中 上面代码的意思是把一个常量字符串的首字符 a 的地址存放到指针变量 pstr 中 注意: C/C++会把常量字符串存储到单独的一个内存区域...函数的使用 qsort是一个库函数,底层使用的快速排序的方式,对数据进行排序的 这个函数可以直接用来使用,这个函数可以用来排序任何类型的数据 首先,我们先了解一下qsort函数的用法 qsort - C+...3.2 数组传参和指针传参 在写代码的时候难免要把【数组】或者【指针】传给函数,那函数的参数该如何设计呢?...数组传参,形参可以写成数组形式、指针类型 3.2.1 一维数组传参 #include void test(int arr[]) {} void test(int arr[10]) {

    88311

    C语言 | 指针数组与多重指针

    C语言什么是指针数组 在C语言中一个数组,若其元素均为指针类型数据,称为指针数组,也就是说,指针数组中的每一个元素都存放一个地址,相当于一个指针变量。...C语言指向指针数据的指针 //定义一个指向指针数据的指针变量: char **point; point的前面有两个*号。...C语言指针数组作main函数的参数 main函数的第一行一般写成 int main() 或 int main(void) 括号中是空的或void,表示main函数没有参数,调用main函数时不必给出实参...命令行的一般形式 命令名 参数1 参数2……参数n C语言指向指针的指针 #include int main() {     int number =100;     int *p1...100道C语言源码案例请去公众号:C语言入门到精通

    1.8K20

    C语言:数组与指针

    对于数组元素的使用,采用的是数组名加下标的方式。 比如有数组 int a[10]; 里面10个元素分别是 a[0]、a[1]、a[2]......a[9]。...引用数组元素,还有另外两种方式。 首先,我们要知道数组名a代表的含义,它表示的是首地址,数组第一个元素a[0]的地址。...数组在内存空间位置是固定的,地址不变,这也就是为什么不能给数组名a赋值或者改变它的值。 那么a+1是什么意思呢?很多人误以为,那就是首地址加一呗。a+1表示的是数组里面第二个元素的地址。...a+i 等价于 &a[i] *(a+i) 等价于 a[i] 第二种方式就是直接使用指针来引用数组元素。...定义指针 int *p; 使用p=a;或者p=&a[0]让指针指向数组第一个元素a[0],那么通过指针p的移动,如p++等也可以遍历数组所有元素。

    1.6K10

    C语言 | 指针引用数组

    C语言数组元素的指针 指针变量既可以指向变量,也可以指向数组元素,所谓数组元素的指针就是数组元素的地址。 引用数组元素可以用下标法,也可以用指针法,即通过指向数组元素的指针找到所需的元素。...在C语言中,数组名代表数组中首元素的地址,使用指针法能使目标程序质量高,因为其占内存少,运行速度快。 C语言在引用数组元素时指针的运算 在一定条件下允许对指针进行加和减的运算。...C语言用数组名作函数参数 C语言调用函数时虚实结合的方法都是采用“值传递”方式,当用变量名作为函数参数时传递的是变量的值,当用数组名作为函数参数时。...C语言通过指针引用多维数组 1、多维数组元素的地址 性质与二维数组差不多,但需要注意的是,多维数组由于分配内存情况不同,所显示的地址可能是不同的。...100道C语言源码案例请去公众号:C语言入门到精通

    1.9K20

    5分钟搞懂C语言的传值和传址

    /* * @author: 冲哥 * @date: 2022/4/14 * @description:交换x,y的值 * @公众号:C语言中文社区 */ #include "stdio.h"...,这个大学生很快地就开始在答题纸上开始写了,他是这样写的: /* * @author: 冲哥 * @date: 2022/4/14 * @description:交换x,y的值 * @公众号:C语言中文社区.../* * @author: 冲哥 * @date: 2022/4/14 * @description:交换x,y的值 * @公众号:C语言中文社区 */ #include "stdio.h"...[640 (4).png] 图中可以清楚地发现,在函数的调用过程中实现的是参数x和y的传址,即把x和y存储单元的地址传递给px和py,swap()函数中的形参不再拥有自己的存储空间,它们分别指向x和y的存储单元...这也是在采用传址的时候修改形参也会影响实参的原因。 通过以上实例是不是就能很容易理解C语言的传值和传址,有什么问题欢迎留言。

    63981
    领券