函数形参传递概念及问题分析

2024-06-11 20:38

本文主要是介绍函数形参传递概念及问题分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

普通函数参数

下面程序试图改变main函数中a和b的值

#include<stdio.h>

void fun(int x,int y)

{

   int c;

   c=a;

   a=b;

   b=c;

}

int main()

{

   int a=1,b=2;

   fun(a,b);

   printf("a=%d b=%d\n",a,b);

   return 0;

}

函数参数传递分析:

实参:

&a 28ff18

a  1

&b 28ff14

b  2

在将实参传递给形参的时候,编译器将实参拷贝一份给形参。

拷贝份的特点为:

1) 值与实参相同

2) 地址与实参不同

拷贝份(形参)

&x 28ff04

x  1

&y 28ff00

y  2

则在函数内部更改拷贝份的时候,只是对函数内部的局部变量改变,而局部变量是存储在栈空间里的,当fun函数执行结束后,这两个变量会自动销毁,不会改变实参的数值。

一级指针作为函数参数

下面程序试图改变main函数中a和b的值

#include<stdio.h>

void fun(int *a,int *b)

{

   int c;

   c=*a;

   *a=*b;

   *b=c;

}

int main()

{

   int *a,*b;

   int x=1,y=2;

   a=&x;

b=&y;

fun(a,b);

   printf("a=%d b=%d\n",x,y);

   return 0;

}

函数参数传递分析

main中变量的存储情况如下

变量地址

变量值

&x: 28ff18

x:1

&y: 28ff14

y:2

指针变量地址

指针变量内容

指针表示地址里的内容

指针变量地址

指针变量内容

指针表示地址里的内容

&a:28ff28

a: &x

*a:  x

&b:28ff24

b: &y

*b:  y

可见在main函数中,指针a和b的地址为28ff28,28ff24。而指针a和b存储的内容为x和y的地址28ff18、28ff14。*a,*b则是代表x和y变量的值。

当调用fun函数时。main中的指针a和b则要拷贝一份给fun函数的形参。则形参的存储情况如下:

形参指针变量地址

形参指针变量内容

形参指针变量存储的地址表示的内容

&a:28f740

a: 28ff18

*a:  x

&b:28f736

b: 28ff14

*b:  y

可见:把实参指针变量传递给形参后。

实参指针和形参指针的地址是不相同的。但是存储的内容确实相同的。均是指向main函数中的x,y变量,当再fun函数中执行c=*a;*a=*b;*b=c;交换语句时。*a和*b为main函数中的x、y变量。这时候将会交换这两个变量的值。

二级指针作为函数参数

如果想在函数中改变父函数中的指针变量呢。

#include<stdio.h>

void fun(int **c)

{

   int *b;

b=(int *)malloc(sizeof(int));

*b=2;

 *c=b;

}

int main()

{

   int *a,x=1;

   a=&x;

   printf("%x\n",a);

   fun(&a);

   printf("%x\n",a);

   return 0;

}

函数的实参存储如下:

指针变量地址

指针变量值

指针变量值表示的内容

&a:28f73b

a:28f740

*a: x 1

变量地址

变量值

&x:28f740

x: 1

函数的形参存储如下

&c

c:(&a)

*c:(a)

**c:(*a=x)

28ff1c

28f73b

28f740

1

局部变量b的存储如下

&b

b(堆空间地址)

*b

28ffeec

391798

2

函数运行完后,指针变量a的指向则为在fun函数中申请的堆空间的地址,存储如下

指针变量地址

指针变量值

指针变量值表示的内容

&a:28f73b

a:381798

*a: 2

将一级指针的地址赋值给形参的话,将会将一级指针的地址,变量值都赋值给二级指针的形参。此时在函数内部,二级指针(c)则能后获得外部一级指针变量(a)的地址、变量值、和普通变量(i)的值。只要知道实参变量的地址,则在函数内部就可以改变实参变量的值。所以这里的二级指针就可以改变一级指针所指向的内容(一级指针变量的值),一级指针所指向地址的内容。函数运行完后,一级指针a则指向申请的堆空间的地址,指向地址的内容则为堆空间存储的内容,不再指向变量i。

指针数组作为函数参数

下面程序是利用指针数组改变数组的值

#include<stdio.h>

void fun(int *c[],int n)

{

   int i;

   for(i=0;i<n;i++){

       *c[i]=0;

    }

}

int main()

{

   int b[3]={1,2,3};

   int *a[3]={b,b+1,b+2};

   fun(a,3);

   return 0;

}

在main函数中变量的存储情况如下

地址

内容

&b[0]:28ff04

b[0]:1

&b[1]:28ff08

b[1]:2

&b[2]:28ff0c

b[2]:3

地址

内容

指向内容

a:28fef8

a[0]:28ff04

*a[0]

a+1:28fefc

a[1]:28ff08

a+2:28ff00

a[2]:28ff0c

这篇关于函数形参传递概念及问题分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1052229

相关文章

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

MOLE 2.5 分析分子通道和孔隙

软件介绍 生物大分子通道和孔隙在生物学中发挥着重要作用,例如在分子识别和酶底物特异性方面。 我们介绍了一种名为 MOLE 2.5 的高级软件工具,该工具旨在分析分子通道和孔隙。 与其他可用软件工具的基准测试表明,MOLE 2.5 相比更快、更强大、功能更丰富。作为一项新功能,MOLE 2.5 可以估算已识别通道的物理化学性质。 软件下载 https://pan.quark.cn/s/57