|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
标准C库函数5
诊断函数
assert()函数是诊断函数,它的作用是测试一个表达式的值是否为false,也就是为0,并且在条件为false时终止程序,参数表达式的结果。
例题1:诊断函数的应用
- #include<stdio.h>
- #include<assert.h>
- struct ITEM
- {
- int key;
- int value;
- };
- //诊断ITEM结构对象是否为false
- void additem(struct ITEM*itemptr)
- {
- assert(itemptr!=NULL);
- }
- int main()
- {
- additem(NULL);
- return 0;
- }
复制代码
例题分析:
assert()诊断函数程序出现了错误对话框和运行结果,因为诊断结果为false,运行结果很明确地表示出程序出错地原因、出错地文件及其出错代码所在行,这样有利于我们及时修正代码。
命令行参数
标准C语言允许主函数main()有或没有参数列表,所以我们可以在主函数main()中使用一个或多个参数,比如下面主函数的形式:
int main(int argc, char*argv[])
这是main()函数通常的写法,其中,第一个参数argc是英文argument counter的简写,表示传递给主函数main()多少个参数,第2个参数argv[]以字符串数组的形式接收真正的参数,它是英文argument value的简写。
main()函数本身是索引为0的参数,所以argc至少为1。用户在控制台环境中在程序路径和名称的后面键入参数,将传递给argv[1]、argv[2]等。
例题2:命令行参数的应用
- #include<stdio.h>
- #include<stdlib.h>
- int main(int argc,char*argv[])
- {
- int a,b,c;
- a=atoi(argv[1]);
- b=atoi(argv[2]);
- c=a+b;
- printf("First Number:%d\n",a);
- printf("Second Number:%d\n",b);
- printf("%d+%d=%d\n",a,b,c);
- return 0;
- }
复制代码
例题分析:
有些情况下我们需要执行带参数的main()函数,此范例中是把输入的参数作为整数来运算,根据需要,可以转换成不同的形式。
exit()函数
exit()函数表示结束程序,它的返回值将被忽略。如果使用exit()函数,需要包含<stdlib.h>头文件。
函数原型如下:
void exit(int retval);
例题3:exit()函数的应用
- #include<stdio.h>
- #include<stdlib.h>
- int main()
- {
- int i;
- for(i=0;i<10;i++)
- {
- if(i==5)exit(0);
- else
- {
- printf("%d",i);
- getchar();
- }
- }
- getchar();
- return 0;
- }
复制代码
例题分析:
当i值为5时,执行exit()函数,终止程序,exit()函数的返回值将被忽略。
qsort()函数
qsort()函数包含在<stdlib.h>头文件中,此函数根据给出的比较条件进行快速排序,通过指针移动实现排序。排序之后的结果仍然放在原数组中。使用qsort()函数必须自己写一个比较函数。
函数原型为:
void qsort(void*base,int n,int size,int(*fcmp)(const void*,const void*));
例题4:qsort()函数的应用
- #include<stdio.h>
- #include<stdlib.h>
- #include<string.h>
- char stringlist[5][6]={"boy","girl","man","woman","human"};
- int intlist[5]={3,2,5,1,4};
- int sort_stringfun(const void*a,const void*b);
- int sort_intfun(const void*a,const void*b);
- int main(void)
- {
- int x;
- printf("字符串排序:\n");
- qsort((void*)stringlist,5, sizeof(stringlist[0]),sort_stringfun); //调用快速排序函数
- for(x=0;x<5;x++)
- printf("%s\n",stringlist[x]);
- printf("整数排序:\n");
- qsort((void*)intlist,5,sizeof(intlist[0]),sort_intfun);
- for(x=0;x<5;x++)
- printf("%d\n",intlist[x]);
- return 0;
- }
- int sort_stringfun(const void*a,const void*b)
- {
- return (strcmp((const char*)a,(const char*)b));
- }
- int sort_intfun(const void*a,const void*b)
- {
- return*(int*)a-*(int*)b;
- }
复制代码
例题分析:
需要注意的是void*数据类型,需要针对不同的数据类型进行必要的转换。
综合应用——猜数字游戏
例题5:猜数字游戏。随机生成一个1~9之间的任意整数作为被猜数字,循环输入你猜的数字,告诉你猜大了还是猜小了,直到猜中,同时统计猜的次数。
- #include<stdio.h>
- #include<stdlib.h>
- #include<string.h>
- #include<ctype.h>
- #include<math.h>
- #define MAX 9
- int main()
- {
- int b=0;
- int n; //所猜的数字
- int sum=0;
- char array[100]; //猜数的次数
- char*p=array;
- int num;
- srand((unsigned)time(NULL)); //随机数播种函数
- num=1+rand()%MAX; //设定随机数
- printf("随机数已经准备好,范围1到9.\n");
- while(!b) //猜不对就一直循环
- {
- sum+=1;
- printf("请输入你猜的数字\n");
- scanf("%s",p);
- if(strlen(p)==1)
- {
- if(isalpha(*p)!=0)
- {
- printf("请输入数学,不是字母\n");
- }
- else if(ispunct(*p)!=0)
- {
- printf("请输入数字,不是标点符号\n");
- }
- else
- {
- n=atoi(p);
- if(n==num)
- {
- b=1;
- printf("你太聪明了!你共猜了%d次\n",sum);
- }
- else if(n<num&&n>0)
- {
- printf("你猜小了!继续努力!\n");
- }
- else if(n>num&&n<=9)
- {
- printf("你猜大了!继续努力!\n");
- }
- }
- }
- else
- {
- printf("数字范围是1到9,你输入的数据不对!\n");
- }
- }
- return 0;
- }
复制代码
例题分析:
标准输入输出函数、随机函数和循环选择组合,可以完成很多有趣的项目。本范例中再通过字符类型判断,对用户错误的输入提示得更准确。
|
|