c语言函数---M




书画小说软件 制作更满意的读、更舒心的写、更轻松的公布

最全古典小说网 由本软件公布所得







                      main()主函数 每一C 程序都必须有一main()函数, 能够依据自己的爱好把它放在程序的某 

个地方。有些程序猿把它放在最前面, 而还有一些程序猿把它放在最后面, 不管放

在哪个地方, 下面几点说明都是适合的。

    1. main() 參数 在Turbo C2.0启动过程中, 传递main()函数三个參数: argc, argvenv

* argc: 整数, 为传给main()的命令行參数个数。

* argv: 字符串数组。 在DOS 3.X 版本号中, argv[0] 为程序运行的全路径名; 对DOS 3.0 下面的版本号, argv[0]为空串("") 。

argv[1] 为在DOS命令行中运行程序名后的第一个字符串; argv[2] 为运行程序名后的第二个字符串; ... argv[argc]为NULL。 *env: 安符串数组。

env[] 的每个元素都包括ENVVAR=value形式的字符

串。

当中ENVVAR为环境变量如PATH或87。value 为ENVVAR的相应值如C:\DOS, C:

\TURBOC(对于PATH) 或YES(对于87)

Turbo C2.0启动时总是把这三个參数传递给main()函数, 能够在用户程序中

说明(或不说明)它们, 假设说明了部分(或所有)參数, 它们就成为main()子程序

的局部变量。

    请注意: 一旦想说明这些參数, 则必须按argc, argv, env 的顺序, 例如以下面 

的样例:

     main() main(int argc) main(int argc, char *argv[]) main(int argc, char *argv[], char *env[]) 

当中另外一种情况是合法的, 但不常见, 由于在程序中非常少有仅仅用argc, 而不

用argv[]的情况。

    下面提供一例子程序EXAMPLE.EXE,  演示怎样在main()函数中使用三个參数: /*program name EXAMPLE.EXE*/ #include <stdio.h> #include <stdlib.h> main(int argc, char *argv[], char *env[]) { int i; printf("These are the %d  command- line  arguments passed  to main:\n\n", argc); for(i=0; i<=argc; i++) printf("argv[%d]:%s\n", i, argv[i]); printf("\nThe environment string(s)on this system are:\n\n"); for(i=0; env[i]!=NULL; i++) printf(" env[%d]:%s\n", i, env[i]); } 假设在DOS 提示符下, 按下面方式执行EXAMPLE.EXE: C:\example first_argument "argument with blanks"  3  4  "last  but 
one" stop! 注意: 能够用双引號括起内含空格的參数, 如本例中的:   "  argument 
with blanks"和"Last but one")。

结果是这种: The value of argc is 7 These are the 7 command-linearguments passed to main: argv[0]:C:\TURBO\EXAMPLE.EXE argv[1]:first_argument argv[2]:argument with blanks argv[3]:3 argv[4]:4 argv[5]:last but one argv[6]:stop! argv[7]:(NULL) The environment string(s) on this system are: env[0]: COMSPEC=C:\COMMAND.COM env[1]: PROMPT=$P$G /*视详细设置而定*/ env[2]: PATH=C:\DOS;C:\TC /*视详细设置而定*/

应该提醒的是: 传送main() 函数的命令行參数的最大长度为128 个字符 (包

括參数间的空格), 这是由DOS 限制的。

函数名: matherr

功 能: 用户可改动的数学错误处理程序

用 法: int matherr(struct exception *e);

程序例:

/* This is a user-defined matherr function that prevents any error messages from being printed. */ 
#include<math.h> 
int matherr(struct exception *a) 
{ return 1; 
} 

函数名: memccpy

功 能: 从源source中拷贝n个字节到目标destin中

用 法: void *memccpy(void *destin, void *source, unsigned char ch,

       unsigned n); 

程序例:

#include <string.h> 
#include <stdio.h> 
int main(void) 
{ char *src = "This is the source string"; char dest[50]; char *ptr; ptr = memccpy(dest, src, 'c', strlen(src)); if (ptr) { *ptr = '\0'; printf("The character was found:  %s\n", dest); } else printf("The character wasn't found\n"); return 0; 
} 

函数名: malloc

功 能: 内存分配函数

用 法: void *malloc(unsigned size);

程序例:

#include <stdio.h> 
#include <string.h> 
#include <alloc.h> 
#include <process.h> 
int main(void) 
{ char *str; /* allocate memory for string */ /* This will generate an error when compiling */ /* with C++, use the new operator instead. */ if ((str = malloc(10)) == NULL) { printf("Not enough memory to allocate buffer\n"); exit(1);  /* terminate program if out of memory */ } /* copy "Hello" into string */ strcpy(str, "Hello"); /* display string */ printf("String is %s\n", str); /* free memory */ free(str); return 0; 
} 

函数名: memchr

功 能: 在数组的前n个字节中搜索字符

用 法: void *memchr(void *s, char ch, unsigned n);

程序例:

#include <string.h> 
#include <stdio.h> 
int main(void) 
{ char str[17]; char *ptr; strcpy(str, "This is a string"); ptr = memchr(str, 'r', strlen(str)); if (ptr) printf("The character 'r' is at position: %d\n", ptr - str); else printf("The character was not found\n"); return 0; 
} 

函数名: memcpy

功 能: 从源source中拷贝n个字节到目标destin中

用 法: void *memcpy(void *destin, void *source, unsigned n);

程序例:

#include <stdio.h> 
#include <string.h> 
int main(void) 
{ char src[] = "******************************"; char dest[] = "abcdefghijlkmnopqrstuvwxyz0123456709"; char *ptr; printf("destination before memcpy: %s\n", dest); ptr = memcpy(dest, src, strlen(src)); if (ptr) printf("destination after memcpy:  %s\n", dest); else printf("memcpy failed\n"); return 0; 
} 

函数名: memicmp

功 能: 比較两个串s1和s2的前n个字节, 忽略大写和小写

用 法: int memicmp(void *s1, void *s2, unsigned n);

程序例:

#include <stdio.h> 
#include <string.h> 
int main(void) 
{ char *buf1 = "ABCDE123"; char *buf2 = "abcde456"; int stat; stat = memicmp(buf1, buf2, 5); printf("The strings to position 5 are "); if (stat) printf("not "); printf("the same\n"); return 0; 
} 

函数名: memmove

功 能: 移动一块字节

用 法: void *memmove(void *destin, void *source, unsigned n);

程序例:

#include <string.h> 
#include <stdio.h> 
int main(void) 
{ char *dest = "abcdefghijklmnopqrstuvwxyz0123456789"; char *src = "******************************"; printf("destination prior to memmove: %s\n", dest); memmove(dest, src, 26); printf("destination after memmove:    %s\n", dest); return 0; 
} 

函数名: memset

功 能: 设置s中的全部字节为ch, s数组的大小由n给定

用 法: void *memset(void *s, char ch, unsigned n);

程序例:

#include <string.h> 
#include <stdio.h> 
#include <mem.h> 
int main(void) 
{ char buffer[] = "Hello world\n"; printf("Buffer before memset: %s\n", buffer); memset(buffer, '*', strlen(buffer) - 1); printf("Buffer after memset:  %s\n", buffer); return 0; 
} 

函数名: mkdir

功 能: 建立一个文件夹

用 法: int mkdir(char *pathname);

程序例:

#include <stdio.h> 
#include <conio.h> 
#include <process.h> 
#include <dir.h> 
int main(void) 
{ int status; clrscr(); status = mkdir("asdfjklm"); (!status) ? (printf("Directory created\n")) : (printf("Unable to create directory\n")); getch(); system("dir"); getch(); status = rmdir("asdfjklm"); (!status) ? (printf("Directory deleted\n")) : (perror("Unable to delete directory")); return 0; 
} 

函数名: mktemp

功 能: 建立唯一的文件名称

用 法: char *mktemp(char *template);

程序例:

#include <dir.h> 
#include <stdio.h> 
int main(void) 
{ /* fname defines the template for the temporary file.  */ char *fname = "TXXXXXX", *ptr; ptr = mktemp(fname); printf("%s\n",ptr); return 0; 
} 

函数名: MK_FP

功 能: 设置一个远指针

用 法: void far *MK_FP(unsigned seg, unsigned off);

程序例:

#include <dos.h> 
#include <graphics.h> 
int main(void) 
{ int gd, gm, i; unsigned int far *screen; detectgraph(&gd, &gm); if (gd == HERCMONO) screen = MK_FP(0xB000, 0); else screen = MK_FP(0xB800, 0); for (i=0; i<26; i++) screen[i] = 0x0700 + ('a' + i); return 0; 
} 

函数名: modf

功 能: 把数分为指数和尾数

用 法: double modf(double value, double *iptr);

程序例:

#include <math.h> 
#include <stdio.h> 
int main(void) 
{ double fraction, integer; double number = 100000.567; fraction = modf(number, &integer); printf("The whole and fractional parts of %lf are %lf and %lf\n", number, integer, fraction); return 0; 
} 

函数名: movedata

功 能: 拷贝字节

用 法: void movedata(int segsrc, int offsrc, int segdest,

  int offdest, unsigned numbytes); 

程序例:

#include <mem.h> 
#define MONO_BASE 0xB000 
/* saves the contents of the monochrome screen in buffer */ 
void save_mono_screen(char near *buffer) 
{ movedata(MONO_BASE, 0, _DS, (unsigned)buffer, 80*25*2); 
} 
int main(void) 
{ char buf[80*25*2]; save_mono_screen(buf); 
} 

函数名: moverel

功 能: 将当前位置(CP)移动一相对距离

用 法: void far moverel(int dx, int dy);

程序例:

#include <graphics.h> 
#include <stdlib.h> 
#include <stdio.h> 
#include <conio.h> 
int main(void) 
{ /* request auto detection */ int gdriver = DETECT, gmode, errorcode; char msg[80]; /* initialize graphics and local variables */ initgraph(&gdriver, &gmode, ""); /* read result of initialization */ errorcode = graphresult(); if (errorcode != grOk)  /* an error occurred */ { printf("Graphics error: %s\n", grapherrormsg(errorcode)); printf("Press any key to halt:"); getch(); exit(1); /* terminate with an error code */ } /* move the C.P. to location (20, 30) */ moveto(20, 30); /* plot a pixel at the C.P. */ putpixel(getx(), gety(), getmaxcolor()); /* create and output a message at (20, 30) */ sprintf(msg, " (%d, %d)", getx(), gety()); outtextxy(20, 30, msg); /* move to a point a relative distance */ /* away from the current value of C.P. */ moverel(100, 100); /* plot a pixel at the C.P. */ putpixel(getx(), gety(), getmaxcolor()); /* create and output a message at C.P. */ sprintf(msg, " (%d, %d)", getx(), gety()); outtext(msg); /* clean up */ getch(); closegraph(); return 0; 
} 

函数名: movetext

功 能: 将屏幕文本从一个矩形区域复制到还有一个矩形区域

用 法: int movetext(int left, int top, int right, int bottom,

  int newleft, int newtop); 

程序例:

#include <conio.h> 
#include <string.h> 
int main(void) 
{ char *str = "This is a test string"; clrscr(); cputs(str); getch(); movetext(1, 1, strlen(str), 2, 10, 10); getch(); return 0; 
} 

函数名: moveto

功 能: 将CP移到(x, y)

用 法: void far moveto(int x, int y);

程序例:

#include <graphics.h> 
#include <stdlib.h> 
#include <stdio.h> 
#include <conio.h> 
int main(void) 
{ /* request auto detection */ int gdriver = DETECT, gmode, errorcode; char msg[80]; /* initialize graphics and local variables */ initgraph(&gdriver, &gmode, ""); /* read result of initialization */ errorcode = graphresult(); if (errorcode != grOk)  /* an error occurred */ { printf("Graphics error: %s\n", grapherrormsg(errorcode)); printf("Press any key to halt:"); getch(); exit(1); /* terminate with an error code */ } /* move the C.P. to location (20, 30) */ moveto(20, 30); /* plot a pixel at the C.P. */ putpixel(getx(), gety(), getmaxcolor()); /* create and output a message at (20, 30) */ sprintf(msg, " (%d, %d)", getx(), gety()); outtextxy(20, 30, msg); /* move to (100, 100) */ moveto(100, 100); /* plot a pixel at the C.P. */ putpixel(getx(), gety(), getmaxcolor()); /* create and output a message at C.P. */ sprintf(msg, " (%d, %d)", getx(), gety()); outtext(msg); /* clean up */ getch(); closegraph(); return 0; 
} 

函数名: movemem

功 能: 移动一块字节

用 法: void movemem(void *source, void *destin, unsigned len);

程序例:

#include <mem.h> 
#include <alloc.h> 
#include <stdio.h> 
#include <string.h> 
int main(void) 
{ char *source = "Borland International"; char *destination; int length; length = strlen(source); destination = malloc(length + 1); movmem(source,destination,length); printf("%s\n",destination); return 0; 
} 

函数名: normvideo

功 能: 选择正常亮度字符

用 法: void normvideo(void);

程序例:

#include <conio.h> 
int main(void) 
{ normvideo(); cprintf("NORMAL Intensity Text\r\n"); return 0; 
} 

函数名: nosound

功 能: 关闭PC扬声器

用 法: void nosound(void);

程序例:

/* Emits a 7-Hz tone for 10 seconds. True story: 7 Hz is the resonant frequency of a chicken's skull cavity. This was determined empirically in Australia, where a new factory generating 7-Hz tones was located too close to a chicken ranch: When the factory started up, all the chickens died. Your PC may not be able to emit a 7-Hz tone. 
*/ 
int main(void) 
{ sound(7); delay(10000); nosound(); 
} 



书画小说软件 制作更满意的读、更舒心的写、更轻松的公布

最全古典小说网 由本软件公布所得

转载于:https://www.cnblogs.com/bhlsheji/p/5257960.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/373499.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Apache ActiveMQ的JMS开发基础

去年是我尝试JMS的时候。 背后的想法和概念让我有些困惑&#xff0c;但是当我知道它的用途后&#xff0c;我很快就掌握了它。 在本文中&#xff0c;我将展示使用Apache ActiveMQ作为后端使用Java开发简单的生产者/消费者的基础。 让我们首先从概念开始&#xff0c;这是一个简单…

vijos p1460——拉力赛

描述 车展结束后&#xff0c;游乐园决定举办一次盛大的山道拉力赛&#xff0c;平平和韵韵自然也要来参加大赛。 赛场上共有n个连通的计时点&#xff0c;n-1条赛道&#xff08;构成了一棵树&#xff09;。每个计时点的高度都不相同&#xff08;父结点的高度必然大于子结点&#…

mysql acid_Mysql中ACID的原理

原子性 (Atomicity)原子性是指一个事务是一个不可分割的工作单位&#xff0c;其中的操作要么都做&#xff0c;要么都不做。隔离性 (Isolation)隔离性是指多个事务并发执行的时候&#xff0c;事务内部的操作与其他事务是隔离的&#xff0c;并发执行的各个事务之间不能互相干扰…

MongoDB 自动删除集合中过期的数据——TTL索引

简介 ​ TTL (Time To Live, 有生命周期的) 索引是特殊单字段索引&#xff0c;MongoDB可以用来在一定时间后自动从集合中删除文档的特殊索引。 这对于某些类型的数据非常好&#xff0c;例如机器生成的事件数据&#xff0c;日志和会话信息&#xff0c;这些信息只需要在数据库中…

PLSQL 经常自动断开失去连接的解决过程

问题背景&#xff1a; 情况是这样的&#xff0c;很多开发同事的PLSQL上班时间开着8个小时&#xff0c;有时候他们出去抽烟后或者中午吃完饭&#xff0c;回来在PLSQL上面执行就报错无响应&#xff0c;然后卡住了半天动弹不了&#xff0c;非得重新登录plsql才生效&#xff0c;我猜…

使用Cobertura,JUnit,HSQLDB,JPA涵盖您的测试

你好&#xff01;你好吗&#xff1f; 今天让我们谈谈一个非常有用的工具&#xff0c;名为“ Cobertura”。 该框架与我们在另一篇文章中看到的Emma框架具有相同的功能。 Cobertura和Emma之间的主要区别在于Cobertura显示带有图形的简历页面。 如果要查看有关该主题的其他主题…

fedora mysql gui_fedora8安装 mysql++失败!!装了一个晚上没搞定!!伤心阿!

fedora8安装 mysql失败&#xff01;&#xff01;装了一个晚上没搞定&#xff01;&#xff01;伤心阿&#xff01;发布时间:2008-02-24 05:15:27来源:红联作者:lygzx[rootF8 mysql-3.0.0]# ./configure --w/usr/lib/mysqlconfigure: error: unrecognized option: --w/usr/lib/my…

MongoDB 数组类型查询 —— $elemMatch 操作符

描述 $elemMatch 数组查询操作用于查询数组值中至少有一个能完全匹配所有的查询条件的文档。语法格式如下&#xff1a; { <field>: { $elemMatch: { <query1>, <query2>, ... } } }如果只有一个查询条件就没必要使用 $elemMatch。 限制 不能指定 $where 查…

MVC4 Action 方法的执行

1. ActionInvoker 的执行&#xff1a; 在MVC 中 包括Model绑定与验证在内的整个Action的执行是通过一个名为ActionInvoker的组件来完成的。 它同样具有 同步/异步两个版本。 分别实现了接口 IActionInvoker /IAsyncActionInvoker。 ASP.NET MVC 中真正用于Action方法同步和异步…

C# 基础知识总结

要学好C#&#xff0c;基础知识的重要性不言而喻&#xff0c;现将常用到的一些基础进行总结&#xff0c;总结如下&#xff1a; 01. 数据类型转换&#xff1a; 强制类型转换(Chart--> int): char crA; int i (int)(cr); 02. 委托/匿名函数/Lamda表达式&#xff1a; 委托是匿…

Java注释和真实世界的Spring示例

“注释”是编程语言定义的一种&#xff0c;用作“标记”。 可以将它们视为编程语言引擎可以理解的注释行。 它们不会直接影响程序的执行&#xff0c;但是会在需要时间接影响。 定义 注释使用interface关键字定义&#xff0c;并且与接口相似。 它具有定义类似于接口方法的属性。…

scrapy+mysql+pipeline+更新数据_python3+Scrapy爬虫实战(二)—— 使用pipeline数据保存到文本和数据库(mysql)...

前言保存本地存储Json数据配置setting保存数据库创建数据库创建表编写pipelines配置setting本文是对上篇文章所讲的代码进一步优化&#xff0c;回看可以点这里&#xff0c;代码就直接在上一篇代码中进行改造&#xff0c;没有的小伙伴可以在这里下载。前言Scrapy 提供了 pipelin…

NYOJ 44 子串和

子串和 时间限制&#xff1a;5000 ms | 内存限制&#xff1a;65535 KB难度&#xff1a;3描述 给定一整型数列{a1,a2...,an}&#xff0c;找出连续非空子串{ax,ax1,...,ay}&#xff0c;使得该子序列的和最大&#xff0c;其中&#xff0c;1<x<y<n。 输入 第一行是一个…

学习进度条

学习进度条 周次 学习时间 新编写代码行数 博客量&#xff08;篇&#xff09; 学到知识点 第一周 160 0 1 github的使用和认识软件工程这门课的价值。 第二周 160 130 3 复利的计算和Github的一些简单操作还有就是进行项目的开发分析&#xff0c;还有就是对…

ARM基础

1.  将32位a的【7&#xff1a;4】改成0101 -> a a&(~(0xF << 4)) | (0x5 << 4)&#xff1b; 2.  32位&#xff1a;单次处理数据32位。 3.  对于CPU而言&#xff0c;一切皆内存&#xff1b; 4.  DMA总线&#xff1a;不经过CPU直接在内存和内存间交换…

使用Jolokia和JMX进行客户端服务器监视

Java监视工具的选择非常广泛&#xff08;由Google提供的随机选择和顺序&#xff09;&#xff1a; javamelody 压力探头 JVisualVM 控制台 贾蒙 Java JMX Nagios插件不适用 此外&#xff0c;还有各种专用工具&#xff0c;例如ActiveMQ &#xff0c; JBoss &#xff0c; Qu…

图书管理系统数据字典_2. 结构化——数据字典

返回目录&#xff1a;Chilan Yuk&#xff1a;软件工程分析设计图库目录​zhuanlan.zhihu.com一、基本知识用于定义数据流和数据存储的结构&#xff0c;并给出构成所给的数据流和数据存储的各数据项的基本数据类型。数据字典中应该包括关于数据的如下信息一般信息&#xff08;名…

HDOJ 5184 Brackets 卡特兰数扩展

既求从点(0,0)仅仅能向上或者向右而且不穿越yx到达点(a,b)有多少总走法... 有公式: C(ab,min(a,b))-C(ab,min(a,b)-1) /// 折纸法证明卡特兰数: http://blog.sina.com.cn/s/blog_6917f47301010cno.html Brackets Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65…

010-python基础-数据类型-字符串操作

1、移除空白 1 username.strip() 2、分割 1 names "alex,jack,rain" 2 names_1 names.split(",") #  字符串分割之后变成列表 3 print(names_1) 4 #输出 5 [alex, jack, rain] 3、合并列表各元素成为字符串 1 names_1 [alex, jack, rain]2 names_2…

重复次数最多的 子串_每日算法系列【LeetCode 424】替换后的最长重复字符

题目描述给你一个仅由大写英文字母组成的字符串&#xff0c;你可以将任意位置上的字符替换成另外的字符&#xff0c;总共可最多替换 k 次。在执行上述操作后&#xff0c;找到包含重复字母的最长子串的长度。示例1输入&#xff1a; s "ABAB", k 2 输出&#xff1a; …