零基础入门学习C语言008讲:函数(2)

版权声明:转载请标明出处 https://blog.csdn.net/qq_41556318/article/details/89683483

8.4 函数的调用

8.4.1 函数调用的一般形式

函数调用的一般形式为: 函数名(实参表列)

如果是调用无参函数,则实参表列可以没有,但括弧不能省略。

如果实参表列包含多个实参,则各参数间用逗号隔开。实参与形参的个数应相等,类型应匹配。实参与形参按顺序对应,一一传递数据。

如果实参表列包括多个实参,对实参求值的顺序并不是确定的,有的系统按自左至右顺序求实参的值,有的系统则按自右至左顺序。

许多C版本是按自右而左的顺序求值,例如Tubro C++。

#include <stdio.h>
void main()
{
	int f(int a, int b);//函数声明
	int i = 2, p;
	p = f(i, ++i);//函数调用
	printf("%d\n", p);
}

int f(int a, int b) //函数定义
{
	int c;
	if (a > b)
	{
		c = 1;
	}
	else if (a == b)
	{
		c = 0;
	}
	else
	{
		c = -1;
	}
	return(c);
}

两种调用

8.4.2函数调用的方式

按函数在程序中出现的位置来分,可以有以下三种函数调用方式:

1.函数语句

把函数调用作为一个语句。如例8.1中的printstar(),这时不要求函数带回值,只要求函数完成一定的操作。

2.函数表达式

函数出现在一个表达式中,这种表达式称为函数表达式。这时要求函数带回一个确定的值以参加表达式的运算。例如:c=2*max(a,b);

3.函数参数

函数调用作为一个函数的实参。例如:

m = max (a , max ( b , c ) ) ;

其中max ( b , c )是一次函数调用,它的值作为max另一次调用的实参。m的值是a、b、c三者中的最大者。又如:  printf ("%d", max (a,b));也是把max ( a , b )作为printf函数的一个参数。

  函数调用作为函数的参数,实质上也是函数表达式形式调用的一种,因为函数的参数本来就要求是表达式形式。

8.4.3对被调用函数的声明和函数原型

在一个函数中调用另一函数(即被调用函数)需要具备哪些条件呢?

(1) 首先被调用的函数必须是已经存在的函数(是库函数或用户自己定义的函数)。但光有这一条件还不够。

(2) 如果使用库函数,还应该在本文件开头用#include命令将调用有关库函数时所需用到的信息“包含”到本文件中来。

(3) 如果使用用户自己定义的函数,而该函数的位置在调用它的函数(即主调函数)的后面(在同一个文件中),应该在主调函数中对被调用的函数作声明

关键词区别一下

“声明”一词的原文是delaration,过去在许多书中把它译为“说明”。声明的作用是把函数名、函数参数的个数和参数类型等信息通知编译系统,以便在遇到函数调用时,编译系统能正确识别函数并检查调用是否合法。 (例如函数名是否正确,实参与形参的类型和个数是否一致)。

函数的“定义”和“声明”不是一回事函数的定义是指对函数功能的确立,包括指定函数名,函数值类型、形参及其类型、函数体等,它是一个完整的、独立的函数单位。(占内存)

函数的声明的作用则是把函数的名字、函数类型以及形参的类型、个数和顺序通知编译系统,以便在调用该函数时系统按此进行对照检查。(不占内存)

例8.5 对被调用的函数作声明

#include "stdio.h"

void main()
{
	float add(float x, float y); /*对被调用函数add的声明*/
	float a, b, c;
	scanf("%f,%f", &a, &b);
	c = add(a, b);
	printf("sum is %f\n", c);
}

float add(float x, float y) /*函数首部*/
{
	float z;
	z = x + y;
	return(z);
}

另外,还有点说明下~

如果  被调用函数的定义出现在主调函数之前,可以不必加以声明。因为编译系统已经先知道了已定义函数的有关情况,会根据函数首部提供的信息对函数的调用作正确性检查。

即将上面的代码改为这样:

#include "stdio.h"

float add(float x, float y) /*函数首部*/
{
	float z;
	z = x + y;
	return(z);
}

void main()
{
	//float add(float x, float y); /*对被调用函数add的声明*/
	float a, b, c;
	scanf("%f,%f", &a, &b);
	c = add(a, b);
	printf("sum is %f\n", c);
}

给大家练练手感~

1.自己实现pow()函数并尝试验证……

#include "stdio.h"

//函数声明
double power(double x, double y);

void main()
{
	double x = 2.0, y = 3.0, z;
	//函数调用
	z = power(x, y);
	printf("%0.1f 的 %0.1f 次方的结果是%0.1f", x, y, z);
}

//函数定义
double power(double x, double y)
{
	double z = 1;
	while (y)
	{
		z *= x;
		--y;
	}
	return z;
}

2.猜想下sqrt()函数的原理并尝试编程……(暂时只要求整型数据)

#include "stdio.h"

//函数声明
int sqrt_02(int x);

void main()
{
	int x=0, answer;
	//函数调用
	answer = sqrt_02(x);
	if (answer < 0)
	{
		printf("你输入的数据有误,请输入能被开方的整数。\n");
	}
	else
	{
		printf("%d 开方的结果是%d\n", x, answer);
	}
	
}

//函数定义
int sqrt_02(int x)
{
	int temp = x / 2;
	while (temp >= 0)
	{
		if (temp*temp == x)
		{
			return temp;
		}
		else
		{
			temp--;
		}
	}
	return -1;

}

3.编写一个用来统计输入的各个数字、空白符(空格、制表符、换行符)以及所有其他字符出现次数的程序。

    分别存储在变量num[10], blank, others里边并打印出来……

一直读不到文件的EOF标志,将getc函数的返回值类型改为int类型(也就是将下面的第4行中的char改为int即可),就可以顺利的判断EOF的标志了。查阅资料得知,EOF为整型,不是字符型。

#include "stdio.h"

void main()
{
	int c, num[10] = {0}, blank, others;
	blank = others = 0;
	while ((c = getchar()) != EOF)
	{
		if (c ==' '||c=='\t'||c=='\n')
		{
			blank++;
		}
		else if (c >= '0'&&c <= '9')
		{
			num[c-48]++;
		}
		else
		{
			others++;
		}		
	}
	printf("%d\n", blank);
	printf("%d\n", others);
	for (int i = 0; i < 10; i++)
	{
		printf("%d %d\n", i, num[i]);
	}
}

猜你喜欢

转载自blog.csdn.net/qq_41556318/article/details/89683483