C语言入门教程-函数库

电子常识

2651人已加入

描述

函数库

C语言本身具备最基本功能,所以C函数库就显得十分重要了。C语言本身甚至不提供从键盘读入和向屏幕输出的I/O函数。所有对基本语言功能的扩展都必须由程序员编写。由此而产生的大量代码常常组织在一些函数库中,以方便重复使用。我们前面已经用到标准I/O(stdio)函数库了。标准库包括标准I/O、数学函数、字符串处理、时间操作等等。您可以在自己的程序中使用函数库的概念将代码划分为多个模块。这样更有利于代码的理解、测试和调试,也使重复使用其他程序的代码成为可能。

创建自己的函数库很容易。作为例子,我们将使用本教程前文中的部分代码,用其中的两个函数创建一个函数库。我们从下面的代码开始:

#include 
#define MAX 10

int a[MAX];
int rand_seed=10;

int rand()
/* 摘自 K&R
 - 产生一个0至32767之间的随机数。*/
{rand_seed = rand_seed * 1103515245 +12345;
return (unsigned int)(rand_seed / 65536) % 32768;}

void main()

{int i,t,x,y;/* 填充数组元素 */
for (i=0; i < MAX; i++)
{a[i]=rand();printf("%d\n",a[i]);}
/* 将数组用冒泡法排序 */
for (x=0; x < MAX-1; x++)
for (y=0; y < MAX-x-1; y++)
if (a[y] > a[y+1])
{t=a[y];a[y]=a[y+1];a[y+1]=t;}
/* 打印排序后的数组 */
printf("--------------------
\n
");for (i=0; i < MAX; i++)
printf("%d
\n",a[i]);}

这段代码先用随机数填充一个数组,然后用冒泡法对这些数排序,最后打印排序后的数组。

用您所学的知识,把冒泡排序的代码提出来建立一个函数。因为数组a和常数MAX都是全局的,所以您建立这个函数不需要参数,也不用返回结果。但是应该将x、y和t修改为局部变量。

经测试确认函数可以正常工作后,再将数组元素个数作为函数的参数传入而不使用MAX:

#include 

#define MAX 10

int a[MAX];
int rand_seed=10;
/* 摘自 K&R                                                               

 - 产生一个0至32767之间的随机数。*/             
int rand()
{rand_seed = rand_seed * 1103515245 +12345;return (unsigned int)(rand_seed / 65536) % 32768;}

void bubble_sort(int m)
{int x,y,t;for (x=0; x < m-1; x++)
for (y=0; y < m-x-1; y++)
if (a[y] > a[y+1])
{t=a[y];a[y]=a[y+1];a[y+1]=t;}
}

void main()
{int i,t,x,y;
/* 填充数组元素 */for (i=0; i < MAX; i++)
{a[i]=rand();printf("%d
\n",a[i]);}bubble_sort(MAX);/* 打印排序后的数组 */
printf("--------------------
\n");for (i=0; i < MAX; i++)printf("%d\n",a[i]);}

您可以将a也作为输入参数以进一步增强bubble_sort函数的适用性:

bubble_sort(int m, int a[])

这行的意思是:“参数a是一个任意大小的整型数组。”bubble_sort的函数体不用进行任何修改。使用bubble_sort时,要将调用改成:

bubble_sort(MAX, a);

请注意,尽管排序会改变a,但是函数调用并没有使用&a。这样做的原因,当您了解指针后会很清楚。

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分