c语言函数作为函数参数

C语言函数名作为参数被另外一个函数调用

要将函数名作为参数,需要使用函数指针。

函数指针的定义格式为

ret_type

(*var_name)(arg_list);

表示返回值为ret_type,参数列表为arg_list的函数指针var_name.

int

(*p)(int,int);

表示返回值为int,参数为两个int型的函数指针p。

以函数指针作为形参,即可实现函数名作为参数,由另一个函数调用。

void func(int (*a)(int))

{

int r = 100l;

(*a)(r);

}即可传入函数指针,并以r为参数,调用该指针指向的函数。

c语言中用函数做参数怎么用

数组元素就是下标变量,它与普通变量并无区别。 因此它作为函数实参使用与普通变量是完全相同的,在发生函数调用时,把作为实参的数组元素的值传送给形参,实现单向的值传送。【例5-4】说明了这种情况。

【例8-7】判别一个整数数组中各元素的值,若大于0 则输出该值,若小于等于0则输出0值。编程如下:#include stdio.hvoid nzp(int v){ if(v0) printf(“%d “,v); else printf(“%d “,0);}int main(void){ int a[5],i; printf(“input 5 numbers\n”); for(i=0;i5;i++){ scanf(“%d”,a[i]); nzp(a[i]); } return 0;}

本程序中首先定义一个无返回值函数nzp,并说明其形参v为整型变量。在函数体中根据v值输出相应的结果。在main函数中用一个for语句输入数组各元素,每输入一个就以该元素作实参调用一次nzp函数,即把a[i]的值传送给形参v,供nzp函数使用。

数组名作为函数参数

用数组名作函数参数与用数组元素作实参有几点不同。

1) 用数组元素作实参时,只要数组类型和函数的形参变量的类型一致,那么作为下标变量的数组元素的类型也和函数形参变量的类型是一致的。因此,并不要求函数的形参也是下标变量。换句话说,对数组元素的处理是按普通变量对待的。用数组名作函数参数时,则要求形参和相对应的实参都必须是类型相同的数组,都必须有明确的数组说明。当形参和实参二者不一致时,即会发生错误。

2) 在普通变量或下标变量作函数参数时,形参变量和实参变量是由编译系统分配的两个不同的内存单元。在函数调用时发生的值传送是把实参变量的值赋予形参变量。在用数组名作函数参数时,不是进行值的传送,即不是把实参数组的每一个元素的值都赋予形参数组的各个元素。因为实际上形参数组并不存在,编译系统不为形参数组分配内存。那么,数据的传送是如何实现的呢?在我们曾介绍过,数组名就是数组的首地址。因此在数组名作函数参数时所进行的传送只是地址的传送,也就是说把实参数组的首地址赋予形参数组名。形参数组名取得该首地址之后,也就等于有了实在的数组。实际上是形参数组和实参数组为同一数组,共同拥有一段内存空间。

上图说明了这种情形。图中设a为实参数组,类型为整型。a占有以2000为首地址的一块内存区。b为形参数组名。当发生函数调用时,进行地址传送,把实参数组a的首地址传送给形参数组名b,于是b也取得该地址2000。于是a,b两数组共同占有以2000为首地址的一段连续内存单元。从图中还可以看出a和b下标相同的元素实际上也占相同的两个内存单元(整型数组每个元素占二字节)。例如a[0]和b[0]都占用2000和2001单元,当然a[0]等于b[0]。类推则有a[i]等于b[i]。

【例8-8】数组a中存放了一个学生5门课程的成绩,求平均成绩。#include stdio.hfloat aver(float a[5]){ int i; float av,s=a[0]; for(i=1;i5;i++) s=s+a[i]; av=s/5; return av;}int main(void){ float sco[5],av; int i; printf(“\ninput 5 scores:\n”); for(i=0;i5;i++) scanf(“%f”,sco[i]); av=aver(sco); printf(“average score is %5.2f”,av); return 0;}

本程序首先定义了一个实型函数aver,有一个形参为实型数组a,长度为5。在函数aver中,把各元素值相加求出平均值,返回给主函数。主函数main 中首先完成数组sco的输入,然后以sco作为实参调用aver函数,函数返回值送av,最后输出av值。 从运行情况可以看出,程序实现了所要求的功能。

3) 前面已经讨论过,在变量作函数参数时,所进行的值传送是单向的。即只能从实参传向形参,不能从形参传回实参。形参的初值和实参相同,而形参的值发生改变后,实参并不变化,两者的终值是不同的。而当用数组名作函数参数时,情况则不同。由于实际上形参和实参为同一数组,因此当形参数组发生变化时,实参数组也随之变化。当然这种情况不能理解为发生了“双向”的值传递。但从实际情况来看,调用函数之后实参数组的值将由于形参数组值的变化而变化。为了说明这种情况,把【例5.4】改为【例5.6】的形式。

【例8-9】题目同【例8.7】。改用数组名作函数参数。#include stdio.hvoid nzp(int a[5]){ int i; printf(“\nvalues of array a are:\n”); for(i=0;i5;i++){ if(a[i]0) a[i]=0; printf(“%d “,a[i]); }}int main(void){ int b[5],i; printf(“\ninput 5 numbers:\n”); for(i=0;i5;i++) scanf(“%d”,b[i]); printf(“initial values of array b are:\n”); for(i=0;i5;i++) printf(“%d “,b[i]); nzp(b); printf(“\nlast values of array b are:\n”); for(i=0;i5;i++) printf(“%d “,b[i]); return 0;}

本程序中函数nzp的形参为整数组a,长度为5。主函数中实参数组b也为整型,长度也为5。在主函数中首先输入数组b的值,然后输出数组b的初始值。然后以数组名b为实参调用nzp函数。在nzp中,按要求把负值单元清0,并输出形参数组a的值。 返回主函数之后,再次输出数组b的值。从运行结果可以看出,数组b的初值和终值是不同的,数组b的终值和数组a是相同的。这说明实参形参为同一数组,它们的值同时得以改变。

用数组名作为函数参数时还应注意以下几点:

①形参数组和实参数组的类型必须一致,否则将引起错误。

②形参数组和实参数组的长度可以不相同,因为在调用时,只传送首地址而不检查形参数组的长度。当形参数组的长度与实参数组不一致时,虽不至于出现语法错误(编译能通过),但程序执行结果将与实际不符,这是应予以注意的。

【例8.10】如把例8.9修改如下:#include stdio.hvoid nzp(int a[8]){ int i; printf(“\nvalues of array aare:\n”); for(i=0;i8;i++){ if(a[i]0)a[i]=0; printf(“%d “,a[i]); }}int main(void){ int b[5],i; printf(“\ninput 5 numbers:\n”); for(i=0;i5;i++) scanf(“%d”,b[i]); printf(“initial values of array b are:\n”); for(i=0;i5;i++) printf(“%d “,b[i]); nzp(b); printf(“\nlast values of array b are:\n”); for(i=0;i5;i++) printf(“%d “,b[i]); return 0;}

本程序与【例8.9】程序比,nzp函数的形参数组长度改为8,函数体中,for语句的循环条件也改为i8。因此,形参数组a和实参数组b的长度不一致。编译能够通过,但从结果看,数组a的元素a[5]、a[6]、a[7]显然是无意义的。

③在函数形参表中,允许不给出形参数组的长度,或用一个变量来表示数组元素的个数。例如,可以写为:

void nzp(int a[])

或写为

void nzp( int a[], int n )

其中形参数组a没有给出长度,而由n值动态地表示数组的长度。n的值由主调函数的实参进行传送。由此,【例8-10】又可改为【例8-11】的形式。

【例8-11】复制纯文本新窗口

#include stdio.hvoid nzp(int a[],int n){ int i; printf(“\nvalues of array a are:\n”); for(i=0;in;i++){ if(a[i]0) a[i]=0; printf(“%d “,a[i]); }}int main(void){ int b[5],i; printf(“\ninput 5 numbers:\n”); for(i=0;i5;i++) scanf(“%d”,b[i]); printf(“initial values of array b are:\n”); for(i=0;i5;i++) printf(“%d “,b[i]); nzp(b,5); printf(“\nlast values of array b are:\n”); for(i=0;i5;i++) printf(“%d “,b[i]); return 0;}

c语言函数作为函数参数

【C语言】函数作为函数参数

Question:在函数void function()中,需要将另外一个函数double input()的函数名作为参数。

typedef double (*P)(int);

Note:参数部分需要注意,函数input()所有的输入参数类型都需要包含在内。

例如 double input(double u[5], int num, double x), 则在定义时写作 typedef double (*P)(double*,int,double)。

此时,函数作为一种类型,可以直接被其他函数调用。

函数声明中定义 void function(P input),调用function(input)即可。

也可以写成

c语言 函数做函数的形参

主函数的实参是由操作系统传递的。

c++规定的主函数标准格式(c语言未具体规定):int

main(int

argc,

char

*argv[])

其中int

argc

表示操作系统传递给程序的参数个数,char

*argv[]

存储各个参数。

例如:

若有程序如下:

int

main(int

argc,

char

*argv[])

{

int

i;

printf(“您输入了

%d

个参数\n分别是:”,argc);

for(i=0;i

运行-

cmd

输入

c:\app.exe

hello

world!

回车

执行结果将是:

您输入了

3

个参数

分别是:c:\app.exe

hello

world!

注意,第一个参数值将是你程序的文件名。

c语言向函数传递函数作为参数

#include stdio.h

//—子函数声明—// 

int func1();

int func2(int (*func1)());        //形参为函数指针(即指向函数的指针) 

//—主函数—// 

int main(){

    printf(“向函数二传递函数一,\n即函数一作为函数二的参数。\n”);

    printf(“%d “,func1());

    printf(“%d\n”,func2(func1));//注意函数名即为函数地址!!!!!! 

}                                //实参为函数名func1或者func1,两者等价,而非func1() 

//—子函数定义—// 

int func1(){

    return 1;

}

int func2(int (*func1)()){        //形参为函数指针(即指向函数的指针)

    return func1()+1;

}

本文来自投稿,不代表【】观点,发布者:【

本文地址: ,如若转载,请注明出处!

举报投诉邮箱:253000106@qq.com

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2024年3月28日 05:56:35
下一篇 2024年3月28日 06:02:46

相关推荐

  • 关于linux函数级热补丁的信息

    linuxos7.6打补丁 patch文件格式介绍如下:Patch多指补丁的意思比如内存补丁、文件补丁等,也是电脑命令程序的一种。一般用来对文件应用更改。patch-patch.exe-进程信息进程文件:patch或者patch.exe。 容器Linux(前身为CoreOS) CoreOS于2016年更名为Container Linux。顾名思义,Conta…

    2024年5月19日
    3800
  • c语言怎么创建链表,如何用c语言建立链表

    c语言创建链表? 1、在创建列表时要动态为链表分配空间,C语言的库函数提供了几种函数实现动态开辟存储单元。 2、算法:创建一个空链表,插入n个数据;除头结点外,其它结点不用命名。 3、//表示一个学生的信息\x0d\x0astruct node *next; //表示一个NODE类型的指针\x0d\x0a}NODE;\x0d\x0a//写出建立一个带头结点的…

    2024年5月19日
    4500
  • 如何显示四边形的a字母c语言,怎么用c语言显示*****为平行四边形

    c语言问题输出平行四边形 1、C是高级语言:它把高级语言的基本结构和语句与低级语言的实用性结合起来。C 语言可以像汇编语言一样对位、字节和地址进行操作,而这三者是计算机最基本的工作单元。 2、处理框(矩形框),表示一般的处理功能。判断框(菱形框),表示对一个给定的条件进行判断,根据给定的条件是否成立决定如何执行其后的操作。它有一个入口,二个出口。输入输出框(…

    2024年5月19日
    3700
  • java词典软件,电子词典java语言程序

    网易有道词典可以翻译文言文吗 有道词典可以离线翻译吗 可以,但是需要下载有道词典。有道词典: 有道词典是由网易有道出品的全球首款基于搜索引擎技术的全能免费语言翻译软件。 具体如下:1,若是想将文言文翻译为外语,那么大家就得先将文言文的内容复制下来,然后打开网易有道词典,选择主页下方的“翻译”功能。 有道词典:有道词典是网易有道出品的一款很小很强大的翻译软件,…

    2024年5月19日
    2900
  • c语言除了log2和e,c语言除了printf输出

    C语言中有没有求绝对值的函数啊?谢谢! 1、有。C语言求绝对值的函数为abs( x )与fbs( x ),abs( x )包含于stdlib.h,且两者均包含于math头文件之下。 2、C语言中求绝对值的函数有两个:abs()和fabs()。abs() 是用来求整型表达式的绝对值,比如:abs(x) 就是求整型变量x的绝对值。 3、C语言的库函数中提供了求绝…

    2024年5月19日
    3400
  • excelif判断日期,判断日期的函数

    excel如何以某个日期进行对比判断是在之前或者之后后返回数值 1、方法一:使用VLOOKUP函数 在Excel表格中创建一个日期列和一个数值列,确保日期列包含您要查找的日期。确定您需要查找的日期,并将其输入到另一个单元格中。 2、公式为 =IF(A1B1,true,false),当A1日期大于B1时显示true,否则显示false。 3、可以使用Excel…

    2024年5月19日
    5400
  • c语言longint,c语言long类型怎么输出

    c语言中int与long的区别 int 用4字节表示,与long相同。目前的操作系统已发展到64位操作系统,但因程序编译工艺的不同,两者表现出不同的差别:32位编译系统:int占四字节,与long相同。 int 最小是占2个字节,long最小是占4个字节;这个是基本的原则,但是现在大多编译器int,long都是4个字节。 长整型是程序设计中数据类型的一种表现…

    2024年5月19日
    3000
  • c语言怎么定义label,C语言怎么定义字符

    C语言中的标识符是怎么定义的? 其余都由用户自定义。C 规定,标识符只能是字母(A~Z,a~z)、数字(0~9)、下划线()组成的字符串,并且其第一个字符必须是字母或下划线。 c语言中标识符是由字母(A-Z,a-z)、数字(0-9)、下划线“_”组成,并且首字符不能是数字,但可以是字母或者下划线。例如,正确的标识符:abc,a1,prog_to。 标示符(i…

    2024年5月19日
    3800
  • c语言的可执行程序是从,c语言的可执行程序是从哪里来的

    1、一个C程序的执行是从___。 1、一个C程序的执行是从main函数开始到main函数结束。C语言是一门面向过程的、抽象化的通用程序设计语言,广泛应用于底层开发。 2、一个c程序的执行是从本程序的main函数开始,到main函数结束。C语言是世界上最流行、使用最广泛的面向过程的高级程序设计语言。 3、一个C语言的执行是从本程序的main函数开始,到main…

    2024年5月19日
    4200
  • 汇编和c语言哪个更中意,汇编和c语言的关系

    用c语言写好,还是用汇编好 编程入门先学C语言或者python。为了解决使用机器语言编写应用程序所带来的一系列问题,人们首先想到使用助记符号来代替不容易记忆的机器指令。这种助记符号来表示计算机指令的语言称为符号语言,也称汇编语言。 汇编语言是直接和电脑硬件打交道的,需要懂一点硬件知识的,如果汇编语言搞懂了c语言学起来更加顺手,建议学习c语言,汇编附带学习一下…

    2024年5月19日
    3200

发表回复

登录后才能评论



关注微信