C/C++的头文件和经典程序代码大全


1 C/C++头文件一览 C、传统 C++ #include //设定插入点 使用断言 assert()宏是用于保证满足某个特定条件,用法是: assert(表达式); 如果表达式的值为假,整个程序将退出,并输出一条错误信息。如果表达式的值为真则继续执行后面的语句。 使用这个宏前需要包含头文件 assert.h 例如 #include #include void main() { float a,b; scan("%f %f",&a,&b); assert(b!=0); printf("%f\n",a/b); } 以上的程序要计算 A/B 的值,因此要求 b!=0,所以在程序中使用了 assert()用于确保 b!=0,如果 b==0, 则程序会退出。 #include //字符处理 isalnum 判断一个字符是否是字符类的数字或者字母 isalpha 判断一个字符是否是字母 isblank 判断一个字符是空白字符(空格和水平制表符 Tab) iscntrl 判断一个控制符(ascii 码 0-31 之间的字符) isdigit 判断一个字符是否是字符类的数字 isgraph 判断一个字符是否是可打印字符(ascii 码 33-126 之间的字符) islower 判断一个字符是否是小写字母 isprint 判断一个字符是否是包含空格在内的可打印字符(ascii 码 32-126 之间的字符) ispunct 判断一个字符是否是除空格,字母,数字外的标点符号 isspace 判断一个字符是空白字符(空格,换行符(\n),走纸符(\f),回车符(\r),垂直制表符(\v),水平制表 符(\t)) isupper 判断一个字符是否是大写字母 isxdigit 判断一个字符是否是一个十六进制的数字 tolower 将大些字符转换为小写 toupper 将小写字符转换为大写 isalnum()函数的作用是判断一个字符是否是字符类的数字或者字母: #include #include int main(void) { if(isalnum('a')) printf("It's True"); // 显示 It's True if(isalnum(4)) printf("It's True"); // 显示 '' if(isalnum('4')) printf("It's True"); // 显示 It's True return 0; } isalpha()函数的作用是判断一个字符是否是字母: #include #include int main(void) { if(isalpha('a')) printf("It's True"); // 显示 It's True if(isalpha(4)) printf("It's True"); // 显示 '' if(isalpha('4')) printf("It's True"); // 显示 '' 2 return 0; } isblank()函数的作用是判断一个字符是空白字符(空格和水平制表符 Tab),isspace()函数和 isblank()函数 类似,但是还包含空格,换行符(\n),走纸符(\f),回车符(\r),垂直制表符(\v),水平制表符(\t): #include #include int main(void) { if(isblank(' ')) // 空格 printf("It's True"); // 显示 It's True if(isblank('\t')) // Tab printf("It's True"); // 显示 It's True if(isblank('\n')) // 换行 printf("It's True"); // 显示 '' if(isblank('\r')) // 回车 printf("It's True"); // 显示 '' if(isspace(' ')) // 空格 printf("It's True"); // 显示 It's True if(isspace('\t')) // Tab printf("It's True"); // 显示 It's True if(isspace('\n')) // 换行 printf("It's True"); // 显示 It's True if(isspace('\r')) // 回车 printf("It's True"); // 显示 It's True return 0; } iscntrl()函数的作用是判断一个控制符(ascii 码 0-31 之间的字符): #include #include int main(void) { if(isblank(' ')) // 空格 printf("It's True"); // 显示 '' if(isblank('\t')) // Tab printf("It's True"); // 显示 It's True if(isblank('\n')) // 换行 printf("It's True"); // 显示 It's True if(isblank('\r')) // 回车 printf("It's True"); // 显示 It's True return 0; } isdigit()函数的作用是判断一个字符是否是字符类的数字: #include #include int main(void) { if(isdigit('4')) printf("It's True"); // 显示 It's True if(isdigit(4)) printf("It's True"); // 显示 '' if(isdigit('a')) printf("It's True"); // 显示 '' return 0; } isgraph()函数的作用是判断一个字符是否是可打印字符(ascii 码 33-126 之间的字符),isprint()函数功能 和 isgraph()函数类似,区别是 isprint()函数包含空格在内(ascii 码 32-126 之间的字符): #include #include int main(void) { 3 if(isgraph('a')) printf("It's True"); // 显示 It's True if(isgraph('.')) printf("It's True"); // 显示 It's True if(isgraph(' ')) // 空格 printf("It's True"); // 显示 '' if(isprint('a')) printf("It's True"); // 显示 It's True if(isprint('.')) printf("It's True"); // 显示 It's True if(isprint(' ')) // 空格 printf("It's True"); // 显示 It's True return 0; } islower()函数的作用是判断一个字符是否是小写字母,isupper()函数的作用是判断一个字符是否是大写字母: #include #include int main(void) { if(islower('a')) printf("It's True"); // 显示 It's True if(islower('A')) printf("It's True"); // 显示 '' if(isupper('a')) printf("It's True"); // 显示 '' if(isupper('A')) printf("It's True"); // 显示 It's True return 0; } ispunct()函数的作用是判断一个字符是否是除空格,字母,数字外的标点符号: #include #include int main(void) { if(ispunct('a')) printf("It's True"); // 显示 '' if(ispunct('.')) printf("It's True"); // 显示 It's True if(ispunct('<')) printf("It's True"); // 显示 It's True return 0; } isxdigit()函数的作用是判断一个字符是否是一个十六进制的数字: #include #include int main(void) { if(isxdigit('4')) printf("It's True"); // 显示 It's True if(isxdigit('xE')) printf("It's True"); // 显示 It's True if(isxdigit('xF')) printf("It's True"); // 显示 '' return 0; } tolower()函数的作用是将大些字符转换为小写,toupper()函数的作用是将小写字符转换为大写: #include #include int main(void) { 4 char n,m,i,j; n = tolower('A'); m = tolower('a'); i = toupper('a'); j = toupper('.'); printf("%c %c %c %c", n, m, i, j); // 显示 a a A . return 0; #include //定义错误码 #include //浮点数处理 #include //文件输入/输出 #include //参数化输入/输出 #include //数据流输入/输出 #include //定义各种数据类型最值常量 #include //定义本地化函数 #include //定义数学函数 #include //定义输入/输出函数 下面的类型,宏,函数都是分类的 其他: size_t sizeof 返回的值 NULL 空指针 文件: FILE 文件的类型 fpos_t 文件中指针的位置 EOF 文件末尾<0 FILENAME_MAX 文件名最大值>0 FOPEN_MAX 同时打开文件的最大值>8 SEEK_SET 文件头 SEEK_CUR 文件当前位置 SEEK_END 文件末尾 打开文件 FILE *fopen(const char *filename,const char *mode); 更改当前流相关的文件 FILE *freopen(const char *filename,const char *mode,FILE *stream); 关闭文件 int fclose(FILE *stream); 清除流中的错误标志或文件末尾标志 void clearerr(FILE *stream); 测试流上的文件末尾标志 int feof(FILE *stream); 测试流上的错误标志 int ferror(FILE *stream); 将一个字符放回到流中 int ungetc(int c, FILE *stream); 从流中读一个字符 int fgetc(FILE *stream); int getc(FILE *stream);/* 与 fgetc 相同但是可以用宏实现该函数 */ 写一个字符到一个流 int fputc(int c, FILE *stream); int putc(int c, FILE *stream); 从流中获取一个字符串 char *fgets(char *s, int n, FILE *stream); 写一个字符串到一个流 int fputs(const char *s, FILE *stream); 打印一个格式化数据到一个流 int fprintf(FILE *stream,const char *format, ...); 使用一个参量列表指针格式化到流的数据 int vfprintf(FILE *stream,const char *format, va_list ap); 从一个流中读取格式化数据 int fscanf(FILE *stream, const char *format, ...); 从一个流中读数据 5 size_t fread(char *buffer,size_t size,size_t count,FILE *stream); 写数据到一个流 int fwrite(const char *buffer, size_t size, size_t count, FILE *stream); 获取流的文件位置指示符 int fgetpos(FILE *stream, fpos_t *pos); 设置流位置指示符 int fsetpos(FILE *stream, const fpos_t *pos); 移动文件指针到一个指定的位置 int fseek(FILE *stream, long offset, int origin); 获得文件指针相对于文件头的偏移量 long ftell(FILE *stream); 重新定位一个文件指针到文件开头 void rewind(FILE *steam); 删除一个文件 int remove(const char *path); 更改一个文件或目录 int rename(const char *oldname, const char *newname); 缓冲区: _IOFBF _IOLBF _IONBF 缓冲区类型 BUFSIZE 缓冲区尺寸>=256 刷新一个流并清空与流相关的缓冲区的内容 int fflush(FILE *stream); 控制流的缓冲区,已经被 setvbuf 代替 void setbuf(FILE *stream, char *buffer); 控制流的缓冲区类型和缓冲区大小 int setvbuf(FILE *stream, char *buffer, int mode, size_t size); 将一个格式化数据写入一个字符串 int sprintf(char *buffer, const char *format, ...); 从字符串中读格式化数据 int sscanf(const char *buffer, const char *format, ...); 从参量列表指针格式化到字符串 int vsprintf(char *buffer, const char *format, va_list ap); 临时文件 L_tmpnam 临时文件名长度>0 TMP_MAX 产生唯一文件名的最大数目>=25 以二进制读写的方式建立一个临时文件 FILE *tmpfile(void); 建立一个临时文件名 char *tmpname(char *string); 标准流: stdin 标准输入流 stdout 标准输出流 stderr 标准错误输出流 从 stdin 获得一个字符 int getchar(void); 把字符写道 stdout int putchar(int c); 从 stdin 中获取一行 char *gets(char *buffer); 写一个字符串到 stdout int puts(const char *string); 打印一个错误消息到 stderr void perror(const char *error); 打印格式化数据到 stdout int printf(const char *format, ...); 从 stdin 读格式化数据 int scanf(const char *format, ...); 6 从参量列表指针格式化到 stdout int vprintf(const char *format, va_list ap); #include //定义杂项函数及内存分配函数 #include //字符串处理 #include //基于数组的输入/输出 #include //定义关于时间的函数 #include //宽字符处理及输入/输出 #include //宽字符分类 标准 C++ (同上的不再注释) #include //STL 通用算法 #include //STL 位集容器 #include #include #include #include #include //复数类 #include #include #include #include #include //STL 双端队列容器 #include //异常处理类 #include #include //STL 定义运算函数(代替运算符) #include #include //STL 线性列表容器 #include //STL 映射容器 #include #include //基本输入/输出支持 #include //输入/输出系统使用的前置声明 #include #include //基本输入流 #include //基本输出流 #include //STL 队列容器 #include //STL 集合容器 #include //基于字符串的流 #include //STL 堆栈容器 #include //标准异常类 #include //底层输入/输出支持 #include //字符串类 #include //STL 通用模板类 #include //STL 动态数组容器 #include #include using namespace std; ////////////////////////////////////////////////////////////////////////// C99 增加 #include //复数处理 #include //浮点环境 #include //整数格式转换 #include //布尔环境 #include //整型环境 #include //通用类型数学宏 C 头文件大全 7 分类函数,所在函数库为 ctype.h int isalpha(int ch) 若 ch 是字母('A'-'Z','a'-'z')返回非 0 值,否则返回 0 int isalnum(int ch) 若 ch 是字母('A'-'Z','a'-'z')或数字('0'-'9') 返回非 0 值,否则返回 0 int isascii(int ch) 若 ch 是字符(ASCII 码中的 0-127)返回非 0 值,否则返回 0 int iscntrl(int ch) 若 ch 是作废字符(0x7F)或普通控制字符(0x00-0x1F) 返回非 0 值,否则返回 0 int isdigit(int ch) 若 ch 是数字('0'-'9')返回非 0 值,否则返回 0 int isgraph(int ch) 若 ch 是可打印字符(不含空格)(0x21-0x7E)返回非 0 值,否则返回 0 int islower(int ch) 若 ch 是小写字母('a'-'z')返回非 0 值,否则返回 0 int isprint(int ch) 若 ch 是可打印字符(含空格)(0x20-0x7E)返回非 0 值,否则返回 0 int ispunct(int ch) 若 ch 是标点字符(0x00-0x1F)返回非 0 值,否则返回 0 int isspace(int ch) 若 ch 是空格(' '),水平制表符('\t'),回车符('\r'), 走纸换行('\f'),垂直制表符('\v'),换行符('\n') 返回非 0 值,否则返回 0 int isupper(int ch) 若 ch 是大写字母('A'-'Z')返回非 0 值,否则返回 0 int isxdigit(int ch) 若 ch 是 16 进制数('0'-'9','A'-'F','a'-'f')返回非 0 值, 否则返回 0 int tolower(int ch) 若 ch 是大写字母('A'-'Z')返回相应的小写字母('a'-'z') int toupper(int ch) 若 ch 是小写字母('a'-'z')返回相应的大写字母('A'-'Z') 数学函数,所在函数库为 math.h、stdlib.h、string.h、float.h int abs(int i) 返回整型参数 i 的绝对值 double cabs(struct complex znum) 返回复数 znum 的绝对值 double fabs(double x) 返回双精度参数 x 的绝对值 long labs(long n) 返回长整型参数 n 的绝对值 double exp(double x) 返回指数函数 ex 的值 double frexp(double value,int *eptr) 返回 value=x*2n 中 x 的值,n 存贮在 eptr 中 double ldexp(double value,int exp); 返回 value*2exp 的值 double log(double x) 返回 logex 的值 double log10(double x) 返回 log10x 的值 double pow(double x,double y) 返回 xy 的值 double pow10(int p) 返回 10p 的值 double sqrt(double x) 返回+√x 的值 double acos(double x) 返回 x 的反余弦 cos-1(x)值,x 为弧度 double asin(double x) 返回 x 的反正弦 sin-1(x)值,x 为弧度 double atan(double x) 返回 x 的反正切 tan-1(x)值,x 为弧度 double atan2(double y,double x) 返回 y/x 的反正切 tan-1(x)值,y 的 x 为弧度 double cos(double x) 返回 x 的余弦 cos(x)值,x 为弧度 double sin(double x) 返回 x 的正弦 sin(x)值,x 为弧度 double tan(double x) 返回 x 的正切 tan(x)值,x 为弧度 double cosh(double x) 返回 x 的双曲余弦 cosh(x)值,x 为弧度 double sinh(double x) 返回 x 的双曲正弦 sinh(x)值,x 为弧度 double tanh(double x) 返回 x 的双曲正切 tanh(x)值,x 为弧度 double hypot(double x,double y) 返回直角三角形斜边的长度(z), x和 y 为直角边的长度,z2=x2+y2 double ceil(double x) 返回不小于 x 的最小整数 double floor(double x) 返回不大于 x 的最大整数 void srand(unsigned seed) 初始化随机数发生器 int rand() 产生一个随机数并返回这个数 double poly(double x,int n,double c[])从参数产生一个多项式 double modf(double value,double *iptr)将双精度数 value 分解成尾数和阶 double fmod(double x,double y) 返回 x/y 的余数 double frexp(double value,int *eptr) 将双精度数 value 分成尾数和阶 double atof(char *nptr) 将字符串 nptr 转换成浮点数并返回这个浮点数 double atoi(char *nptr) 将字符串 nptr 转换成整数并返回这个整数 double atol(char *nptr) 将字符串 nptr 转换成长整数并返回这个整数 char *ecvt(double value,int ndigit,int *decpt,int *sign) 将浮点数 value 转换成字符串并返回该字符串 8 char *fcvt(double value,int ndigit,int *decpt,int *sign) 将浮点数 value 转换成字符串并返回该字符串 char *gcvt(double value,int ndigit,char *buf) 将数 value 转换成字符串并存于 buf 中,并返回 buf 的指针 char *ultoa(unsigned long value,char *string,int radix) 将无符号整型数 value 转换成字符串并返回该字符串,radix 为转换时所用基数 char *ltoa(long value,char *string,int radix) 将长整型数 value 转换成字符串并返回该字符串,radix 为转换时所用基数 char *itoa(int value,char *string,int radix) 将整数 value 转换成字符串存入 string,radix 为转换时所用基数 double atof(char *nptr) 将字符串 nptr 转换成双精度数,并返回这个数,错误返回 0 int atoi(char *nptr) 将字符串 nptr 转换成整型数, 并返回这个数,错误返回 0 long atol(char *nptr) 将字符串 nptr 转换成长整型数,并返回这个数,错误返回 0 double strtod(char *str,char **endptr)将字符串 str 转换成双精度数,并返回这个数, long strtol(char *str,char **endptr,int base)将字符串 str 转换成长整型数, 并返回这个数, int matherr(struct exception *e) 用户修改数学错误返回信息函数(没有必要使用) double _matherr(_mexcep why,char *fun,double *arg1p, double *arg2p,double retval) 用户修改数学错误返回信息函数(没有必要使用) unsigned int _clear87() 清除浮点状态字并返回原来的浮点状态 void _fpreset() 重新初使化浮点数学程序包 unsigned int _status87() 返回浮点状态字 目录函数,所在函数库为 dir.h、dos.h int chdir(char *path) 使指定的目录 path(如:"C:\\WPS")变成当前的工作目录,成 功返回 0 int findfirst(char *pathname,struct ffblk *ffblk,int attrib)查找指定的文件,成功 返回 0 pathname 为指定的目录名和文件名,如"C:\\WPS\\TXT" ffblk为指定的保存文件信息的一个结构,定义如下: ┏━━━━━━━━━━━━━━━━━━┓ ┃struct ffblk ┃ ┃{ ┃ ┃ char ff_reserved[21]; /*DOS 保留字*/┃ ┃ char ff_attrib; /*文件属性*/ ┃ ┃ int ff_ftime; /*文件时间*/ ┃ ┃ int ff_fdate; /*文件日期*/ ┃ ┃ long ff_fsize; /*文件长度*/ ┃ ┃ char ff_name[13]; /*文件名*/ ┃ ┃} ┃ ┗━━━━━━━━━━━━━━━━━━┛ attrib 为文件属性,由以下字符代表 ┏━━━━━━━━━┳━━━━━━━━┓ ┃FA_RDONLY 只读文件┃FA_LABEL 卷标号┃ ┃FA_HIDDEN 隐藏文件┃FA_DIREC 目录 ┃ ┃FA_SYSTEM 系统文件┃FA_ARCH 档案 ┃ ┗━━━━━━━━━┻━━━━━━━━┛ 例: struct ffblk ff; findfirst("*.wps",&ff,FA_RDONLY); int findnext(struct ffblk *ffblk) 取匹配 finddirst 的文件,成功返回 0 void fumerge(char *path,char *drive,char *dir,char *name,char *ext) 此函数通过盘符 drive(C:、A:等),路径 dir(\TC、\BC\LIB 等), 文件名 name(TC、WPS 等),扩展名 ext(.EXE、.COM 等)组成一个文件名 存与 path 中. int fnsplit(char *path,char *drive,char *dir,char *name,char *ext) 此函数将文件名 path 分解成盘符 drive(C:、A:等),路径 dir(\TC、\BC\LIB 等), 9 文件名 name(TC、WPS 等),扩展名 ext(.EXE、.COM 等),并分别存入相应的变量中. int getcurdir(int drive,char *direc) 此函数返回指定驱动器的当前工作目录名称 drive 指定的驱动器(0=当前,1=A,2=B,3=C 等) direc 保存指定驱动器当前工作路径的变量 成功返回 0 char *getcwd(char *buf,iint n) 此函数取当前工作目录并存入 buf 中,直到 n 个字 节长为为止.错误返回 NULL int getdisk() 取当前正在使用的驱动器,返回一个整数(0=A,1=B,2=C 等) int setdisk(int drive) 设置要使用的驱动器 drive(0=A,1=B,2=C 等), 返回可使用驱动器总数 int mkdir(char *pathname) 建立一个新的目录 pathname,成功返回 0 int rmdir(char *pathname) 删除一个目录 pathname,成功返回 0 char *mktemp(char *template) 构造一个当前目录上没有的文件名并存于 template 中 char *searchpath(char *pathname) 利用 MSDOS 找出文件 filename 所在路径, ,此函数使用 DOS 的 PATH 变量,未找到文件返回 NULL 进程函数,所在函数库为 stdlib.h、process.h void abort() 此函数通过调用具有出口代码 3 的_exit 写一个终止信息于 stderr, 并异常终止程序。无返回值 int exec…装入和运行其它程序 int execl( char *pathname,char *arg0,char *arg1,…,char *argn,NULL) int execle( char *pathname,char *arg0,char *arg1,…, char *argn,NULL,char *envp[]) int execlp( char *pathname,char *arg0,char *arg1,…,NULL) int execlpe(char *pathname,char *arg0,char *arg1,…,NULL,char *envp[]) int execv( char *pathname,char *argv[]) int execve( char *pathname,char *argv[],char *envp[]) int execvp( char *pathname,char *argv[]) int execvpe(char *pathname,char *argv[],char *envp[]) exec函数族装入并运行程序 pathname,并将参数 arg0(arg1,arg2,argv[],envp[])传递给子程序,出错返回-1 在 exec 函数族中,后缀 l、v、p、e 添加到 exec 后, 所指定的函数将具有某种操作能力 有后缀 p时,函数可以利用 DOS 的 PATH 变量查找子程序文件。 l时,函数中被传递的参数个数固定。 v时,函数中被传递的参数个数不固定。 e时,函数传递指定参数 envp,允许改变子进程的环境, 无后缀 e 时,子进程使用当前程序的环境。 void _exit(int status)终止当前程序,但不清理现场 void exit(int status) 终止当前程序,关闭所有文件,写缓冲区的输出(等待输出), 并调用任何寄存器的"出口函数",无返回值 int spawn…运行子程序 int spawnl( int mode,char *pathname,char *arg0,char *arg1,…, char *argn,NULL) int spawnle( int mode,char *pathname,char *arg0,char *arg1,…, char *argn,NULL,char *envp[]) int spawnlp( int mode,char *pathname,char *arg0,char *arg1,…, char *argn,NULL) int spawnlpe(int mode,char *pathname,char *arg0,char *arg1,…, char *argn,NULL,char *envp[]) int spawnv( int mode,char *pathname,char *argv[]) int spawnve( int mode,char *pathname,char *argv[],char *envp[]) int spawnvp( int mode,char *pathname,char *argv[]) int spawnvpe(int mode,char *pathname,char *argv[],char *envp[]) spawn函数族在 mode 模式下运行子程序 pathname,并将参数 arg0(arg1,arg2,argv[],envp[])传递给子程序.出错返回-1 mode为运行模式 mode为 P_WAIT 表示在子程序运行完后返回本程序 P_NOWAIT 表示在子程序运行时同时运行本程序(不可用) 10 P_OVERLAY表示在本程序退出后运行子程序 在 spawn 函数族中,后缀 l、v、p、e 添加到 spawn 后, 所指定的函数将具有某种操作能力 有后缀 p时, 函数利用 DOS 的 PATH 查找子程序文件 l时, 函数传递的参数个数固定. v时, 函数传递的参数个数不固定. e时, 指定参数 envp 可以传递给子程序,允许改变子程序运行环境. 当无后缀 e 时,子程序使用本程序的环境. int system(char *command) 将 MSDOS 命令 command 传递给 DOS 执行 转换子程序,函数库为 math.h、stdlib.h、ctype.h、float.h char *ecvt(double value,int ndigit,int *decpt,int *sign) 将浮点数 value 转换成字符串并返回该字符串 char *fcvt(double value,int ndigit,int *decpt,int *sign) 将浮点数 value 转换成字符串并返回该字符串 char *gcvt(double value,int ndigit,char *buf) 将数 value 转换成字符串并存于 buf 中,并返回 buf 的指针 char *ultoa(unsigned long value,char *string,int radix) 将无符号整型数 value 转换成字符串并返回该字符串,radix 为转换时所用基数 char *ltoa(long value,char *string,int radix) 将长整型数 value 转换成字符串并返回该字符串,radix 为转换时所用基数 char *itoa(int value,char *string,int radix) 将整数 value 转换成字符串存入 string,radix 为转换时所用基数 double atof(char *nptr) 将字符串 nptr 转换成双精度数,并返回这个数,错误返回 0 int atoi(char *nptr) 将字符串 nptr 转换成整型数, 并返回这个数,错误返回 0 long atol(char *nptr) 将字符串 nptr 转换成长整型数,并返回这个数,错误返回 0 double strtod(char *str,char **endptr)将字符串 str 转换成双精度数,并返回这个数, long strtol(char *str,char **endptr,int base)将字符串 str 转换成长整型数, 并返回这个数, int toascii(int c) 返回 c 相应的 ASCII int tolower(int ch) 若 ch 是大写字母('A'-'Z')返回相应的小写字母('a'-'z') int _tolower(int ch) 返回 ch 相应的小写字母('a'-'z') int toupper(int ch) 若 ch 是小写字母('a'-'z')返回相应的大写字母('A'-'Z') int _toupper(int ch) 返回 ch 相应的大写字母('A'-'Z') 诊断函数,所在函数库为 assert.h、math.h void assert(int test) 一个扩展成 if 语句那样的宏,如果 test 测试失败, 就显示一个信息并异常终止程序,无返回值 void perror(char *string) 本函数将显示最近一次的错误信息,格式如下: 字符串 string:错误信息 char *strerror(char *str) 本函数返回最近一次的错误信息,格式如下: 字符串 str:错误信息 int matherr(struct exception *e) 用户修改数学错误返回信息函数(没有必要使用) double _matherr(_mexcep why,char *fun,double *arg1p, double *arg2p,double retval) 用户修改数学错误返回信息函数(没有必要使用) 输入输出子程序,函数库为 io.h、conio.h、stat.h、dos.h、stdio.h、signal.h int kbhit() 本函数返回最近所敲的按键 int fgetchar() 从控制台(键盘)读一个字符,显示在屏幕上 int getch() 从控制台(键盘)读一个字符,不显示在屏幕上 int putch() 向控制台(键盘)写一个字符 int getchar() 从控制台(键盘)读一个字符,显示在屏幕上 int putchar() 向控制台(键盘)写一个字符 int getche() 从控制台(键盘)读一个字符,显示在屏幕上 int ungetch(int c) 把字符 c 退回给控制台(键盘) char *cgets(char *string) 从控制台(键盘)读入字符串存于 string 中 int scanf(char *format[,argument…])从控制台读入一个字符串,分别对各个参数进行 11 赋值,使用 BIOS 进行输出 int vscanf(char *format,Valist param)从控制台读入一个字符串,分别对各个参数进行 赋值,使用 BIOS 进行输出,参数从 Valist param 中取得 int cscanf(char *format[,argument…])从控制台读入一个字符串,分别对各个参数进行 赋值,直接对控制台作操作,比如显示器在显示时字符时即为直接写频方式显示 int sscanf(char *string,char *format[,argument,…])通过字符串 string,分别对各个 参数进行赋值 int vsscanf(char *string,char *format,Vlist param)通过字符串 string,分别对各个 参数进行赋值,参数从 Vlist param 中取得 int puts(char *string) 发关一个字符串 string 给控制台(显示器), 使用 BIOS 进行输出 void cputs(char *string) 发送一个字符串 string 给控制台(显示器), 直接对控制台作操作,比如显示器即为直接写频方式显示 int printf(char *format[,argument,…]) 发送格式化字符串输出给控制台(显示器) 使用 BIOS 进行输出 int vprintf(char *format,Valist param) 发送格式化字符串输出给控制台(显示器) 使用 BIOS 进行输出,参数从 Valist param 中取得 int cprintf(char *format[,argument,…]) 发送格式化字符串输出给控制台(显示器), 直接对控制台作操作,比如显示器即为直接写频方式显示 int vcprintf(char *format,Valist param)发送格式化字符串输出给控制台(显示器), 直接对控制台作操作,比如显示器即为直接写频方式显示, 参数从 Valist param 中取得 int sprintf(char *string,char *format[,argument,…]) 将字符串 string 的内容重新写为格式化后的字符串 int vsprintf(char *string,char *format,Valist param) 将字符串 string 的内容重新写为格式化后的字符串,参数从 Valist param 中取得 int rename(char *oldname,char *newname)将文件 oldname 的名称改为 newname int ioctl(int handle,int cmd[,int *argdx,int argcx]) 本函数是用来控制输入/输出设备的,请见下表: ┌───┬────────────────────────────┐ │cmd 值 │功能 │ ├───┼────────────────────────────┤ │ 0 │取出设备信息 │ │ 1 │设置设备信息 │ │ 2 │把 argcx 字节读入由 argdx 所指的地址 │ │ 3 │在 argdx 所指的地址写 argcx 字节 │ │ 4 │除把 handle 当作设备号(0=当前,1=A,等)之外,均和 cmd=2 时一样 │ │ 5 │除把 handle 当作设备号(0=当前,1=A,等)之外,均和 cmd=3 时一样 │ │ 6 │取输入状态 │ │ 7 │取输出状态 │ │ 8 │测试可换性;只对于 DOS 3.x │ │ 11 │置分享冲突的重算计数;只对 DOS 3.x │ └───┴────────────────────────────┘ int (*ssignal(int sig,int(*action)())()执行软件信号(没必要使用) int gsignal(int sig) 执行软件信号(没必要使用) int _open(char *pathname,int access)为读或写打开一个文件, 按后按 access 来确定是读文件还是写文件,access 值见下表 ┌──────┬────────────────────┐ │access 值 │意义 │ ├──────┼────────────────────┤ │O_RDONLY │读文件 │ │O_WRONLY │写文件 │ │O_RDWR │即读也写 │ │O_NOINHERIT │若文件没有传递给子程序,则被包含 │ │O_DENYALL │只允许当前处理必须存取的文件 │ │O_DENYWRITE │只允许从任何其它打开的文件读 │ │O_DENYREAD │只允许从任何其它打开的文件写 │ │O_DENYNONE │允许其它共享打开的文件 │ └──────┴────────────────────┘ 12 int open(char *pathname,int access[,int permiss])为读或写打开一个文件, 按后按 access 来确定是读文件还是写文件,access 值见下表 ┌────┬────────────────────┐ │access 值│意义 │ ├────┼────────────────────┤ │O_RDONLY│读文件 │ │O_WRONLY│写文件 │ │O_RDWR │即读也写 │ │O_NDELAY│没有使用;对 UNIX 系统兼容 │ │O_APPEND│即读也写,但每次写总是在文件尾添加 │ │O_CREAT │若文件存在,此标志无用;若不存在,建新文件 │ │O_TRUNC │若文件存在,则长度被截为 0,属性不变 │ │O_EXCL │未用;对 UNIX 系统兼容 │ │O_BINARY│此标志可显示地给出以二进制方式打开文件 │ │O_TEXT │此标志可用于显示地给出以文本方式打开文件│ └────┴────────────────────┘ permiss为文件属性,可为以下值: S_IWRITE允许写 S_IREAD允许读 S_IREAD|S_IWRITE 允许读、写 int creat(char *filename,int permiss) 建立一个新文件 filename,并设定 读写性。permiss 为文件读写性,可以为以下值 S_IWRITE允许写 S_IREAD允许读 S_IREAD|S_IWRITE 允许读、写 int _creat(char *filename,int attrib) 建立一个新文件 filename,并设定文件 属性。attrib 为文件属性,可以为以下值 FA_RDONLY 只读 FA_HIDDEN 隐藏 FA_SYSTEM 系统 int creatnew(char *filenamt,int attrib) 建立一个新文件 filename,并设定文件 属性。attrib 为文件属性,可以为以下值 FA_RDONLY 只读 FA_HIDDEN 隐藏 FA_SYSTEM 系统 int creattemp(char *filenamt,int attrib) 建立一个新文件 filename,并设定文件 属性。attrib 为文件属性,可以为以下值 FA_RDONLY 只读 FA_HIDDEN 隐藏 FA_SYSTEM 系统 int read(int handle,void *buf,int nbyte)从文件号为 handle 的文件中读 nbyte 个字符 存入 buf 中 int _read(int handle,void *buf,int nbyte)从文件号为 handle 的文件中读 nbyte 个字符 存入 buf 中,直接调用 MSDOS 进行操作. int write(int handle,void *buf,int nbyte)将 buf 中的 nbyte 个字符写入文件号 为 handle 的文件中 int _write(int handle,void *buf,int nbyte)将 buf 中的 nbyte 个字符写入文件号 为 handle 的文件中 int dup(int handle) 复制一个文件处理指针 handle,返回这个指针 int dup2(int handle,int newhandle) 复制一个文件处理指针 handle 到 newhandle int eof(int *handle)检查文件是否结束,结束返回 1,否则返回 0 long filelength(int handle) 返回文件长度,handle 为文件号 int setmode(int handle,unsigned mode)本函数用来设定文件号为 handle 的文件的打 开方式 int getftime(int handle,struct ftime *ftime) 读取文件号为 handle 的文件的时间, 并将文件时间存于 ftime 结构中,成功返回 0,ftime 结构如下: ┌─────────────────┐ │struct ftime │ │{ │ │ unsigned ft_tsec:5; /*秒*/ │ │ unsigned ft_min:6; /*分*/ │ │ unsigned ft_hour:5; /*时*/ │ │ unsigned ft_day:5; /*日*/ │ │ unsigned ft_month:4;/*月*/ │ │ unsigned ft_year:1; /*年-1980*/ │ │} │ └─────────────────┘ int setftime(int handle,struct ftime *ftime) 重写文件号为 handle 的文件时间, 新时间在结构 ftime 中.成功返回 0.结构 ftime 如下: ┌─────────────────┐ 13 │struct ftime │ │{ │ │ unsigned ft_tsec:5; /*秒*/ │ │ unsigned ft_min:6; /*分*/ │ │ unsigned ft_hour:5; /*时*/ │ │ unsigned ft_day:5; /*日*/ │ │ unsigned ft_month:4;/*月*/ │ │ unsigned ft_year:1; /*年-1980*/ │ │} │ └─────────────────┘ long lseek(int handle,long offset,int fromwhere) 本函数将文件号为 handle 的文件 的指针移到 fromwhere 后的第 offset 个字节处. SEEK_SET 文件开关 SEEK_CUR 当前位置 SEEK_END 文件尾 long tell(int handle) 本函数返回文件号为 handle 的文件指针,以字节表示 int isatty(int handle)本函数用来取设备 handle 的类型 int lock(int handle,long offset,long length) 对文件共享作封锁 int unlock(int handle,long offset,long length) 打开对文件共享的封锁 int close(int handle) 关闭 handle 所表示的文件处理,handle 是从_creat、creat、 creatnew、creattemp、dup、dup2、_open、open 中的一个处调用获得的文件处理 成功返回 0 否则返回-1,可用于 UNIX 系统 int _close(int handle) 关闭 handle 所表示的文件处理,handle 是从_creat、creat、 creatnew、creattemp、dup、dup2、_open、open 中的一个处调用获得的文件处理 成功返回 0 否则返回-1,只能用于 MSDOS 系统 FILE *fopen(char *filename,char *type) 打开一个文件 filename,打开方式为 type, 并返回这个文件指针,type 可为以下字符串加上后缀 ┌──┬────┬───────┬────────┐ │type│读写性 │文本/2 进制文件│建新/打开旧文件 │ ├──┼────┼───────┼────────┤ │r │读 │文本 │打开旧的文件 │ │w │写 │文本 │建新文件 │ │a │添加 │文本 │有就打开无则建新│ │r+ │读/写 │不限制 │打开 │ │w+ │读/写 │不限制 │建新文件 │ │a+ │读/添加 │不限制 │有就打开无则建新│ └──┴────┴───────┴────────┘ 可加的后缀为 t、b。加 b 表示文件以二进制形式进行操作,t 没必要使用 例: ┌──────────────────┐ │#include │ │main() │ │{ │ │ FILE *fp; │ │ fp=fopen("C:\\WPS\\WPS.EXE","r+b");│ └──────────────────┘ FILE *fdopen(int ahndle,char *type) FILE *freopen(char *filename,char *type,FILE *stream) int getc(FILE *stream) 从流 stream 中读一个字符,并返回这个字符 int putc(int ch,FILE *stream)向流 stream 写入一个字符 ch int getw(FILE *stream) 从流 stream 读入一个整数,错误返回 EOF int putw(int w,FILE *stream)向流 stream 写入一个整数 int ungetc(char c,FILE *stream) 把字符 c 退回给流 stream,下一次读进的字符将是 c int fgetc(FILE *stream) 从流 stream 处读一个字符,并返回这个字符 int fputc(int ch,FILE *stream) 将字符 ch 写入流 stream 中 char *fgets(char *string,int n,FILE *stream) 从流 stream 中读 n 个字符存入 string 中 int fputs(char *string,FILE *stream) 将字符串 string 写入流 stream 中 int fread(void *ptr,int size,int nitems,FILE *stream) 从流 stream 中读入 nitems 个长度为 size 的字符串存入 ptr 中 int fwrite(void *ptr,int size,int nitems,FILE *stream) 向流 stream 中写入 nitems 个长度为 size 的字符串,字符串在 ptr 中 int fscanf(FILE *stream,char *format[,argument,…]) 以格式化形式从流 stream 中 14 读入一个字符串 int vfscanf(FILE *stream,char *format,Valist param) 以格式化形式从流 stream 中 读入一个字符串,参数从 Valist param 中取得 int fprintf(FILE *stream,char *format[,argument,…]) 以格式化形式将一个字符 串写给指定的流 stream int vfprintf(FILE *stream,char *format,Valist param) 以格式化形式将一个字符 串写给指定的流 stream,参数从 Valist param 中取得 int fseek(FILE *stream,long offset,int fromwhere) 函数把文件指针移到 fromwhere 所指位置的向后 offset 个字节处,fromwhere 可以为以下值: SEEK_SET 文件开关 SEEK_CUR 当前位置 SEEK_END 文件尾 long ftell(FILE *stream) 函数返回定位在 stream 中的当前文件指针位置,以字节表示 int rewind(FILE *stream) 将当前文件指针 stream 移到文件开头 int feof(FILE *stream) 检测流 stream 上的文件指针是否在结束位置 int fileno(FILE *stream) 取流 stream 上的文件处理,并返回文件处理 int ferror(FILE *stream) 检测流 stream 上是否有读写错误,如有错误就返回 1 void clearerr(FILE *stream) 清除流 stream 上的读写错误 void setbuf(FILE *stream,char *buf) 给流 stream 指定一个缓冲区 buf void setvbuf(FILE *stream,char *buf,int type,unsigned size) 给流 stream 指定一个缓冲区 buf,大小为 size,类型为 type,type 的值见下表 ┌───┬───────────────────────────────┐ │type 值│意义 │ ├───┼───────────────────────────────┤ │_IOFBF│文件是完全缓冲区,当缓冲区是空时,下一个输入操作将企图填满整个缓│ │ │冲区.在输出时,在把任何数据写到文件之前,将完全填充缓冲区. │ │_IOLBF│文件是行缓冲区.当缓冲区为空时,下一个输入操作将仍然企图填整个缓│ │ │冲区.然而在输出时,每当新行符写到文件,缓冲区就被清洗掉. │ │_IONBF│文件是无缓冲的.buf 和 size 参数是被忽略的.每个输入操作将直接从文 │ │ │件读,每个输出操作将立即把数据写到文件中. │ └───┴───────────────────────────────┘ int fclose(FILE *stream) 关闭一个流,可以是文件或设备(例如 LPT1) int fcloseall() 关闭所有除 stdin 或 stdout 外的流 int fflush(FILE *stream) 关闭一个流,并对缓冲区作处理 处理即对读的流,将流内内容读入缓冲区; 对写的流,将缓冲区内内容写入流。成功返回 0 int fflushall() 关闭所有流,并对流各自的缓冲区作处理 处理即对读的流,将流内内容读入缓冲区; 对写的流,将缓冲区内内容写入流。成功返回 0 int access(char *filename,int amode) 本函数检查文件 filename 并返回文件的属性, 函数将属性存于 amode 中,amode 由以下位的组合构成 06可以读、写 04可以读 02可以写 01执行(忽略的) 00 文件存在 如果 filename 是一个目录,函数将只确定目录是否存在 函数执行成功返回 0,否则返回-1 int chmod(char *filename,int permiss) 本函数用于设定文件 filename 的属性 permiss可以为以下值 S_IWRITE允许写 S_IREAD允许读 S_IREAD|S_IWRITE 允许读、写 int _chmod(char *filename,int func[,int attrib]); 本函数用于读取或设定文件 filename 的属性, 当 func=0 时,函数返回文件的属性;当 func=1 时,函数设定文件的属性 若为设定文件属性,attrib 可以为下列常数之一 FA_RDONLY 只读 FA_HIDDEN 隐藏 FA_SYSTEM 系统 接口子程序,所在函数库为:dos.h、bios.h unsigned sleep(unsigned seconds)暂停 seconds 微秒(百分之一秒) int unlink(char *filename)删除文件 filename unsigned FP_OFF(void far *farptr)本函数用来取远指针 farptr 的偏移量 unsigned FP_SEG(void far *farptr)本函数用来没置远指针 farptr 的段值 void far *MK_FP(unsigned seg,unsigned off)根据段 seg 和偏移量 off 构造一个 far 指针 unsigned getpsp()取程序段前缀的段地址,并返回这个地址 char *parsfnm(char *cmdline,struct fcb *fcbptr,int option) 函数分析一个字符串,通常,对一个文件名来说,是由 cmdline 所指的一个命令行. 15 文件名是放入一个 FCB 中作为一个驱动器,文件名和扩展名.FCB 是由 fcbptr 所指 定的.option 参数是 DOS 分析系统调用时,AL 文本的值. int absread(int drive,int nsects,int sectno,void *buffer)本函数功能为读特定的 磁盘扇区,drive 为驱动器号(0=A,1=B 等),nsects 为要读的扇区数,sectno 为开始的逻 辑扇区号,buffer 为保存所读数据的保存空间 int abswrite(int drive,int nsects,int sectno,void *buffer)本函数功能为写特定的 磁盘扇区,drive 为驱动器号(0=A,1=B 等),nsects 为要写的扇区数,sectno 为开始的逻 辑扇区号,buffer 为保存所写数据的所在空间 void getdfree(int drive,struct dfree *dfreep)本函数用来取磁盘的自由空间, drive为磁盘号(0=当前,1=A 等).函数将磁盘特性的由 dfreep 指向的 dfree 结构中. dfree结构如下: ┌───────────────────┐ │struct dfree │ │{ │ │ unsigned df_avail; /*有用簇个数*/ │ │ unsigned df_total; /*总共簇个数*/ │ │ unsigned df_bsec; /*每个扇区字节数*/│ │ unsigned df_sclus; /*每个簇扇区数*/ │ │} │ └───────────────────┘ char far *getdta() 取磁盘转换地址 DTA void setdta(char far *dta)设置磁盘转换地址 DTA void getfat(int drive,fatinfo *fatblkp) 本函数返回指定驱动器 drive(0=当前,1=A,2=B 等)的文件分配表信息 并存入结构 fatblkp 中,结构如下: ┌──────────────────┐ │struct fatinfo │ │{ │ │ char fi_sclus; /*每个簇扇区数*/ │ │ char fi_fatid; /*文件分配表字节数*/│ │ int fi_nclus; /*簇的数目*/ │ │ int fi_bysec; /*每个扇区字节数*/ │ │} │ └──────────────────┘ void getfatd(struct fatinfo *fatblkp) 本函数返回当前驱动器的文件分配表信息, 并存入结构 fatblkp 中,结构如下: ┌──────────────────┐ │struct fatinfo │ │{ │ │ char fi_sclus; /*每个簇扇区数*/ │ │ char fi_fatid; /*文件分配表字节数*/│ │ int fi_nclus; /*簇的数目*/ │ │ int fi_bysec; /*每个扇区字节数*/ │ │} │ └──────────────────┘ int bdos(int dosfun,unsigned dosdx,unsigned dosal)本函数对 MSDOS 系统进行调用, dosdx为寄存器 dx 的值,dosal 为寄存器 al 的值,dosfun 为功能号 int bdosptr(int dosfun,void *argument,unsiigned dosal)本函数对 MSDOS 系统进行调用, argument为寄存器 dx 的值,dosal 为寄存器 al 的值,dosfun 为功能号 int int86(int intr_num,union REGS *inregs,union REGS *outregs) 执行 intr_num 号中断,用户定义的寄存器值存于结构 inregs 中, 执行完后将返回的寄存器值存于结构 outregs 中. int int86x(int intr_num,union REGS *inregs,union REGS *outregs, struct SREGS *segregs)执行 intr_num 号中断,用户定义的寄存器值存于 结构 inregs 中和结构 segregs 中,执行完后将返回的寄存器值存于结构 outregs 中. int intdos(union REGS *inregs,union REGS *outregs) 本函数执行 DOS 中断 0x21 来调用一个指定的 DOS 函数,用户定义的寄存器值 存于结构 inregs 中,执行完后函数将返回的寄存器值存于结构 outregs 中 16 int intdosx(union REGS *inregs,union REGS *outregs,struct SREGS *segregs) 本函数执行 DOS 中断 0x21 来调用一个指定的 DOS 函数,用户定义的寄存器值 存于结构 inregs 和 segregs 中,执行完后函数将返回的寄存器值存于结构 outregs 中 void intr(int intr_num,struct REGPACK *preg)本函数中一个备用的 8086 软件中断接口 它能产生一个由参数 intr_num 指定的 8086 软件中断.函数在执行软件中断前, 从结构 preg 复制用户定义的各寄存器值到各个寄存器.软件中断完成后, 函数将当前各个寄存器的值复制到结构 preg 中.参数如下: intr_num 被执行的中断号 preg为保存用户定义的寄存器值的结构,结构如下 ┌──────────────────────┐ │struct REGPACK │ │{ │ │ unsigned r_ax,r_bx,r_cx,r_dx; │ │ unsigned r_bp,r_si,r_di,r_ds,r_es,r_flags; │ │} │ └──────────────────────┘ 函数执行完后,将新的寄存器值存于结构 preg 中 void keep(int status,int size)以 status 状态返回 MSDOS,但程序仍保留于内存中,所占 用空间由 size 决定. void ctrlbrk(int (*fptr)()) 设置中断后的对中断的处理程序. void disable() 禁止发生中断 void enable() 允许发生中断 void geninterrupt(int intr_num)执行由 intr_num 所指定的软件中断 void interrupt(* getvect(int intr_num))() 返回中断号为 intr_num 的中断处理程序, 例如: old_int_10h=getvect(0x10); void setvect(int intr_num,void interrupt(* isr)()) 设置中断号为 intr_num 的中 断处理程序为 isr,例如: setvect(0x10,new_int_10h); void harderr(int (*fptr)()) 定义一个硬件错误处理程序, 每当出现错误时就调用 fptr 所指的程序 void hardresume(int rescode)硬件错误处理函数 void hardretn(int errcode) 硬件错误处理函数 int inport(int prot) 从指定的输入端口读入一个字,并返回这个字 int inportb(int port)从指定的输入端口读入一个字节,并返回这个字节 void outport(int port,int word) 将字 word 写入指定的输出端口 port void outportb(int port,char byte)将字节 byte 写入指定的输出端口 port int peek(int segment,unsigned offset) 函数返回 segment:offset 处的一个字 char peekb(int segment,unsigned offset)函数返回 segment:offset 处的一个字节 void poke(int segment,int offset,char value) 将字 value 写到 segment:offset 处 void pokeb(int segment,int offset,int value) 将字节 value 写到 segment:offset 处 int randbrd(struct fcb *fcbptr,int reccnt) 函数利用打开 fcbptr 所指的 FCB 读 reccnt 个记录. int randbwr(struct fcb *fcbptr,int reccnt) 函数将 fcbptr 所指的 FCB 中的 reccnt 个记录写到磁盘上 void segread(struct SREGS *segtbl)函数把段寄存器的当前值放进结构 segtbl 中 int getverify() 取检验标志的当前状态(0=检验关闭,1=检验打开) void setverify(int value)设置当前检验状态, value为 0 表示关闭检验,为 1 表示打开检验 int getcbrk()本函数返回控制中断检测的当前设置 int setcbrk(int value)本函数用来设置控制中断检测为接通或断开 当 value=0 时,为断开检测.当 value=1 时,为接开检测 int dosexterr(struct DOSERR *eblkp)取扩展错误.在 DOS 出现错误后,此函数将扩充的 错误信息填入 eblkp 所指的 DOSERR 结构中.该结构定义如下: ┌──────────────┐ │struct DOSERR │ │{ │ │ int exterror;/*扩展错误*/ │ │ char class; /*错误类型*/ │ │ char action; /*方式*/ │ │ char locus; /*错误场所*/ │ 17 │} │ └──────────────┘ int bioscom(int cmd,char type,int port) 本函数负责对数据的通讯工作, cmd可以为以下值: 0 置通讯参数为字节 byte 值 1 发送字符通过通讯线输出 2 从通讯线接受字符 3 返回通讯的当前状态 port为通讯端口,port=0 时通讯端口为 COM1,port=1 时通讯端口为 COM2,以此类推 byte为传送或接收数据时的参数,为以下位的组合: ┌───┬─────┬───┬─────┬───┬─────┐ │byte 值│意义 │byte 值│意义 │byte 值│意义 │ │ ├───┼─────┼───┼─────┼───┼─────┤ │0x02 │7 数据位 │0x03 │8 数据位 │0x00 │1 停止位 │ │ │0x04 │2 停止位 │0x00 │无奇偶性 │0x08 │奇数奇偶性│ │ │0x18 │偶数奇偶性│0x00 │110 波特 │0x20 │150 波特 │ │ │0x40 │300 波特 │0x60 │600 波特 │0x80 │1200 波特 │ │ │0xA0 │2400 波特 │0xC0 │4800 波特 │0xE0 │9600 波特 │ │ └───┴─────┴───┴─────┴───┴─────┘ 例如:0xE0|0x08|0x00|0x03 即表示置通讯口为 9600 波特,奇数奇偶性,1 停止位, 8数据位. 函数返回值为一个 16 位整数,定义如下: 第 15 位 超时 第 14 位 传送移位寄存器空 第 13 位 传送固定寄存器空 第 12 位 中断检测 第 11 位 帧错误 第 10 位 奇偶错误 第 9位 过载运行错误 第 8位 数据就绪 第 7位 接收线信号检测 第 6位 环形指示器 第 5位 数据设置就绪 第 4位 清除发送 第 3位 δ接收线信号检测器 第 2位 下降边环形检测器 第 1位 δ数据设置就绪 第 0位 δ清除发送 int biosdisk(int cmd,int drive,int head,int track, int sector,int nsects,void *buffer) 本函数用来对驱动器作一定的操作,cmd 为功能号, drive为驱动器号(0=A,1=B,0x80=C,0x81=D,0x82=E 等).cmd 可为以下值: 0 重置软磁盘系统.这强迫驱动器控制器来执行硬复位.忽略所有其它参数. 1 返回最后的硬盘操作状态.忽略所有其它参数 2 读一个或多个磁盘扇区到内存.读开始的扇区由 head、track、sector 给出。 扇区号由 nsects 给出。把每个扇区 512 个字节的数据读入 buffer 3 从内存读数据写到一个或多个扇区。写开始的扇区由 head、track、sector 给出。扇区号由 nsects 给出。所写数据在 buffer 中,每扇区 512 个字节。 4 检验一个或多个扇区。开始扇区由 head、track、sector 给出。扇区号由 nsects给出。 5 格式化一个磁道,该磁道由 head 和 track 给出。buffer 指向写在指定 track 上 的扇区磁头器的一个表。 以下 cmd 值只允许用于 XT 或 AT 微机: 6 格式化一个磁道,并置坏扇区标志。 7 格式化指定磁道上的驱动器开头。 8 返回当前驱动器参数,驱动器信息返回写在 buffer 中(以四个字节表示)。 9 初始化一对驱动器特性。 10 执行一个长的读,每个扇区读 512 加 4 个额外字节 11 执行一个长的写,每个扇区写 512 加 4 个额外字节 12 执行一个磁盘查找 13 交替磁盘复位 18 14 读扇区缓冲区 15 写扇区缓冲区 16 检查指定的驱动器是否就绪 17 复核驱动器 18 控制器 RAM 诊断 19 驱动器诊断 20 控制器内部诊 函数返回由下列位组合成的状态字节: 0x00 操作成功 0x01 坏的命令 0x02 地址标记找不到 0x04 记录找不到 0x05 重置失败 0x07 驱动参数活动失败 0x09 企图 DMA 经过 64K 界限 0x0B 检查坏的磁盘标记 0x10 坏的 ECC 在磁盘上读 0x11 ECC校正的数据错误(注意它不是错误) 0x20 控制器失效 0x40 查找失败 0x80 响应的连接失败 0xBB 出现无定义错误 0xFF 读出操作失败 int biodquip() 检查设备,函数返回一字节,该字节每一位表示一个信息,如下: 第 15 位 打印机号 第 14 位 打印机号 第 13 位 未使用 第 12 位 连接游戏 I/O 第 11 位 RS232 端口号 第 8位 未使用 第 7位 软磁盘号 第 6位 软磁盘号, 00为 1 号驱动器,01 为 2 号驱动器,10 为 3 号驱动器,11 为 4 号驱动器 第 5位 初始化 第 4位 显示器模式 00为未使用,01 为 40x25BW 彩色显示卡 10为 80x25BW 彩色显示卡,11 为 80x25BW 单色显示卡 第 3位 母扦件 第 2位 随机存贮器容量,00 为 16K,01 为 32K,10 为 48K,11 为 64K 第 1位 浮点共用处理器 第 0位 从软磁盘引导 int bioskey(int cmd)本函数用来执行各种键盘操作,由 cmd 确定操作。 cmd可为以下值: 0 返回敲键盘上的下一个键。若低 8 位为非 0,即为 ASCII 字符;若低 8 位为 0, 则返回扩充了的键盘代码。 1 测试键盘是否可用于读。返回 0 表示没有键可用;否则返回下一次敲键之值。 敲键本身一直保持由下次调用具的 cmd 值为 0 的 bioskey 所返回的值。 2 返回当前的键盘状态,由返回整数的每一个位表示,见下表: ┌──┬───────────┬───────────┐ │ 位 │为 0 时意义 │为 1 时意义 │ ├──┼───────────┼───────────┤ │ 7 │插入状态 │改写状态 │ │ 6 │大写状态 │小写状态 │ │ 5 │数字状态,NumLock 灯亮 │光标状态,NumLock 灯熄 │ │ 4 │ScrollLock 灯亮 │ScrollLock 灯熄 │ │ 3 │Alt 按下 │Alt 未按下 │ │ 2 │Ctrl 按下 │Ctrl 未按下 │ │ 1 │左 Shift 按下 │左 Shift 未按下 │ 19 │ 0 │右 Shift 按下 │右 Shift 未按下 │ └──┴───────────┴───────────┘ int biosmemory()返回内存大小,以 K 为单位. int biosprint(int cmd,int byte,int port)控制打印机的输入/输出. port为打印机号,0 为 LPT1,1 为 LPT2,2 为 LPT3 等 cmd可以为以下值: 0 打印字符,将字符 byte 送到打印机 1 打印机端口初始化 2 读打印机状态 函数返回值由以下位值组成表示当前打印机状态 0x01 设备时间超时 0x08 输入/输出错误 0x10 选择的 0x20 走纸 0x40 认可 0x80 不忙碌 int biostime(int cmd,long newtime)计时器控制,cmd 为功能号,可为以下值 0 函数返回计时器的当前值 1 将计时器设为新值 newtime struct country *country(int countrycmode,struct country *countryp) 本函数用来控制某一国家的相关信息,如日期,时间,货币等. 若 countryp=-1 时,当前的国家置为 countrycode 值(必须为非 0).否则,由 countryp 所指向的 country 结构用下列的国家相关信息填充: (1)当前的国家(若 countrycode 为 0 或 2)由 countrycode 所给定的国家. 结构 country 定义如下: ┌────────────────────┐ │struct country │ │{ │ │ int co_date; /*日期格式*/ │ │ char co_curr[5]; /*货币符号*/ │ │ char co_thsep[2]; /*数字分隔符*/ │ │ char co_desep[2]; /*小数点*/ │ │ char co_dtsep[2]; /*日期分隔符*/ │ │ char co_tmsep[2]; /*时间分隔符*/ │ │ char co_currstyle; /*货币形式*/ │ │ char co_digits; /*有效数字*/ │ │ int (far *co_case)(); /*事件处理函数*/ │ │ char co_dasep; /*数据分隔符*/ │ │ char co_fill[10]; /*补充字符*/ │ │} │ └────────────────────┘ co_date的值所代表的日期格式是: 0 月日年 1 日月年 2 年月日 co_currstrle的值所代表的货币显示方式是 0 货币符号在数值前,中间无空格 1 货币符号在数值后,中间无空格 2 货币符号在数值前,中间有空格 3 货币符号在数值后,中间有空格 操作函数,所在函数库为 string.h、mem.h mem…操作存贮数组 void *memccpy(void *destin,void *source,unsigned char ch,unsigned n) void *memchr(void *s,char ch,unsigned n) void *memcmp(void *s1,void *s2,unsigned n) int memicmp(void *s1,void *s2,unsigned n) void *memmove(void *destin,void *source,unsigned n) void *memcpy(void *destin,void *source,unsigned n) void *memset(void *s,char ch,unsigned n) 20 这些函数,mem…系列的所有成员均操作存贮数组.在所有这些函数中,数组是 n 字节长. memcpy 从 source 复制一个 n 字节的块到 destin.如果源块和目标块重迭,则选择复制方向, 以例正确地复制覆盖的字节. memmove 与 memcpy 相同. memset 将 s 的所有字节置于字节 ch 中.s 数组的长度由 n 给出. memcmp 比较正好是 n 字节长的两个字符串 s1 和 s2.些函数按无符号字符比较字节,因此, memcmp("0xFF","\x7F",1)返回值大于 0. memicmp 比较 s1 和 s2 的前 n 个字节,不管字符大写或小写. memccpy 从 source 复制字节到 destin.复制一结束就发生下列任一情况: (1)字符 ch 首选复制到 destin. (2)n个字节已复制到 destin. memchr 对字符 ch 检索 s 数组的前 n 个字节. 返回值:memmove 和 memcpy 返回 destin memset返回 s 的值 memcmp 和 memicmp─┬─若 s1s2 返回值大于 0 memccpy若复制了 ch,则返回直接跟随 ch 的在 destin 中的字节的一个指针; 否则返回 NULL memchr返回在 s 中首先出现 ch 的一个指针;如果在 s 数组中不出现 ch,就返回 NULL. void movedata(int segsrc,int offsrc, int segdest,int offdest, unsigned numbytes) 本函数将源地址(segsrc:offsrc)处的 numbytes 个字节 复制到目标地址(segdest:offdest) void movemem(void *source,void *destin,unsigned len) 本函数从 source 处复制一块长 len 字节的数据到 destin.若源地址和目标地址字符串 重迭,则选择复制方向,以便正确的复制数据. void setmem(void *addr,int len,char value) 本函数把 addr 所指的块的第一个字节置于字节 value 中. str…字符串操作函数 char stpcpy(char *dest,const char *src) 将字符串 src 复制到 dest char strcat(char *dest,const char *src) 将字符串 src 添加到 dest 末尾 char strchr(const char *s,int c) 检索并返回字符 c 在字符串 s 中第一次出现的位置 int strcmp(const char *s1,const char *s2) 比较字符串 s1 与 s2 的大小,并返回 s1-s2 char strcpy(char *dest,const char *src) 将字符串 src 复制到 dest size_t strcspn(const char *s1,const char *s2) 扫描 s1,返回在 s1 中有,在 s2 中也有的字符个数 char strdup(const char *s) 将字符串 s 复制到最近建立的单元 int stricmp(const char *s1,const char *s2) 比较字符串 s1 和 s2,并返回 s1-s2 size_t strlen(const char *s) 返回字符串 s 的长度 char strlwr(char *s) 将字符串 s 中的大写字母全部转换成小写字母,并返回转换后的字符串 char strncat(char *dest,const char *src,size_t maxlen) 将字符串 src 中最多 maxlen 个字符复制到字符串 dest 中 int strncmp(const char *s1,const char *s2,size_t maxlen) 比较字符串 s1 与 s2 中的前 maxlen 个字符 char strncpy(char *dest,const char *src,size_t maxlen) 复制 src 中的前 maxlen 个字符到 dest 中 int strnicmp(const char *s1,const char *s2,size_t maxlen) 21 比较字符串 s1 与 s2 中的前 maxlen 个字符 char strnset(char *s,int ch,size_t n) 将字符串 s 的前 n 个字符置于 ch 中 char strpbrk(const char *s1,const char *s2) 扫描字符串 s1,并返回在 s1 和 s2 中均有的字符个数 char strrchr(const char *s,int c) 扫描最后出现一个给定字符 c 的一个字符串 s char strrev(char *s) 将字符串 s 中的字符全部颠倒顺序重新排列,并返回排列后的字符串 char strset(char *s,int ch) 将一个字符串 s 中的所有字符置于一个给定的字符 ch size_t strspn(const char *s1,const char *s2) 扫描字符串 s1,并返回在 s1 和 s2 中均有的字符个数 char strstr(const char *s1,const char *s2) 扫描字符串 s2,并返回第一次出现 s1 的位置 char strtok(char *s1,const char *s2) 检索字符串 s1,该字符串 s1 是由字符串 s2 中定义的定界符所分隔 char strupr(char *s) 将字符串 s 中的小写字母全部转换成大写字母,并返回转换后的字符串 存贮分配子程序,所在函数库为 dos.h、alloc.h、malloc.h、stdlib.h、process.h int allocmem(unsigned size,unsigned *seg)利用 DOS 分配空闲的内存, size为分配内存大小,seg 为分配后的内存指针 int freemem(unsigned seg)释放先前由 allocmem 分配的内存,seg 为指定的内存指针 int setblock(int seg,int newsize)本函数用来修改所分配的内存长度, seg为已分配内存的内存指针,newsize 为新的长度 int brk(void *endds) 本函数用来改变分配给调用程序的数据段的空间数量,新的空间结束地址为 endds char *sbrk(int incr) 本函数用来增加分配给调用程序的数据段的空间数量,增加 incr 个字节的空间 unsigned long coreleft() 本函数返回未用的存储区的长度,以字节为单位 void *calloc(unsigned nelem,unsigned elsize)分配 nelem 个长度为 elsize 的内存空间 并返回所分配内存的指针 void *malloc(unsigned size)分配 size 个字节的内存空间,并返回所分配内存的指针 void free(void *ptr)释放先前所分配的内存,所要释放的内存的指针为 ptr void *realloc(void *ptr,unsigned newsize)改变已分配内存的大小,ptr 为已分配有内 存区域的指针,newsize 为新的长度,返回分配好的内存指针. long farcoreleft() 本函数返回远堆中未用的存储区的长度,以字节为单位 void far *farcalloc(unsigned long units,unsigned long unitsz) 从远堆分配 units 个长度为 unitsz 的内存空间,并返回所分配内存的指针 void *farmalloc(unsigned long size)分配 size 个字节的内存空间, 并返回分配的内存指针 void farfree(void far *block)释放先前从远堆分配的内存空间, 所要释放的远堆内存的指针为 block void far *farrealloc(void far *block,unsigned long newsize)改变已分配的远堆内 存的大小,block 为已分配有内存区域的指针,newzie 为新的长度,返回分配好 的内存指针 时间日期函数,函数库为 time.h、dos.h 在时间日期函数里,主要用到的结构有以下几个: 总时间日期贮存结构 tm ┌──────────────────────┐ │struct tm │ │{ │ │ int tm_sec; /*秒,0-59*/ │ │ int tm_min; /*分,0-59*/ │ │ int tm_hour; /*时,0-23*/ │ 22 │ int tm_mday; /*天数,1-31*/ │ │ int tm_mon; /*月数,0-11*/ │ │ int tm_year; /*自 1900 的年数*/ │ │ int tm_wday; /*自星期日的天数 0-6*/ │ │ int tm_yday; /*自 1 月 1 日起的天数,0-365*/ │ │ int tm_isdst; /*是否采用夏时制,采用为正数*/│ │} │ └──────────────────────┘ 日期贮存结构 date ┌───────────────┐ │struct date │ │{ │ │ int da_year; /*自 1900 的年数*/│ │ char da_day; /*天数*/ │ │ char da_mon; /*月数 1=Jan*/ │ │} │ └───────────────┘ 时间贮存结构 time ┌────────────────┐ │struct time │ │{ │ │ unsigned char ti_min; /*分钟*/│ │ unsigned char ti_hour; /*小时*/│ │ unsigned char ti_hund; │ │ unsigned char ti_sec; /*秒*/ │ │ │ └────────────────┘ char *ctime(long *clock) 本函数把 clock 所指的时间(如由函数 time 返回的时间)转换成下列格式的 字符串:Mon Nov 21 11:31:54 1983\n\0 char *asctime(struct tm *tm) 本函数把指定的 tm 结构类的时间转换成下列格式的字符串: Mon Nov 21 11:31:54 1983\n\0 double difftime(time_t time2,time_t time1) 计算结构 time2 和 time1 之间的时间差距(以秒为单位) struct tm *gmtime(long *clock)本函数把 clock 所指的时间(如由函数 time 返回的时间) 转换成格林威治时间,并以 tm 结构形式返回 struct tm *localtime(long *clock)本函数把 clock 所指的时间(如函数 time 返回的时间) 转换成当地标准时间,并以 tm 结构形式返回 void tzset()本函数提供了对 UNIX 操作系统的兼容性 long dostounix(struct date *dateptr,struct time *timeptr) 本函数将 dateptr 所指的日期,timeptr 所指的时间转换成 UNIX 格式,并返回 自格林威治时间 1970 年 1 月 1 日凌晨起到现在的秒数 void unixtodos(long utime,struct date *dateptr,struct time *timeptr) 本函数将自格林威治时间 1970 年 1 月 1 日凌晨起到现在的秒数 utime 转换成 DOS格式并保存于用户所指的结构 dateptr 和 timeptr 中 void getdate(struct date *dateblk)本函数将计算机内的日期写入结构 dateblk 中以供用户使用 void setdate(struct date *dateblk)本函数将计算机内的日期改成 由结构 dateblk 所指定的日期 void gettime(struct time *timep)本函数将计算机内的时间写入结构 timep 中, 以供用户使用 void settime(struct time *timep)本函数将计算机内的时间改为 由结构 timep 所指的时间 long time(long *tloc)本函数给出自格林威治时间 1970 年 1 月 1 日凌晨至现在所经 过的秒数,并将该值存于 tloc 所指的单元中. int stime(long *tp)本函数将 tp 所指的时间(例如由 time 所返回的时间) 写入计算机中. 23 //根据半径计算圆的周长和面积 #include const float PI=3.1416; //声明常量(只读变量)PI 为 3.1416 float fCir_L(float); //声明自定义函数 fCir_L()的原型 float fCir_S(float); //声明自定义函数 fCir_S()的原型 //以下是 main()函数 main() { float r,l,s; //声明 3 个变量 cout<<"R="; //显示字符串 cin>>r; //键盘输入 l=fCir_L(r); //计算圆的周长,赋值给变量 l s=fCir_S(r); //计算圆的面积,赋值给变量 s cout<<"l="<>c>>n>>x; cout<<"c="<>c1>>c2; cout<<"c1="< //包含 iostream.h 头文件 main() { //声明 bool 变量,并初始化 bool flag1=false,flag2=true; //输出布尔常量和变量 cout<<"false:"<0 && a<=5="<2*b+2||a2*b+2||a main() { //按位与运算 cout<<"24&12="<<(24&12)<>3="<<(5>>3)<>3="<<(-5>>3)< main() { int a=1,b=1,c=3; //显示 a,b,c 的值 cout<<"a="<>a>>b; //利用 cin 从键盘上为变量 a,b 赋值 s=a; if (a>a>>b>>c; if (a<=b) //外层条件语句 { if (a<=c) //内层条件语句 smallest=a; else smallest=c; } else { if (b<=c) //内层条件语句 smallest=b; else smallest=c; } cout<<"Smallest="< main() { int score; //从键盘上输入分数 cout<<"score="; cin>>score; //用带 else if 的条件语句判断处理 if (score<0 || score>100) { cout<<"The score is out of range!"<=90) cout<<"Your grade is a A."<=80) cout<<"Your grade is a B."<=70) cout<<"Your grade is a C."<=60) cout<<"Your grade is a D."< 34 main() { int n; cout<<"n="; cin>>n; if (n>=0 && n<=100 &&n%2==0) cout<<"n="< main() { int a,b,Max; //输入数据 cout<<"a="; cin>>a; cout<<"b="; cin>>b; //找出较大值 Max=a>b?a:b; cout<<"Max="< main() { int a,b; //输入数据 cout<<"a="; cin>>a; cout<<"b="; cin>>b; //除法判断 if (b!=0 && a%b==0) { cout< main() { //x,y 为操作数,c 为运算符 int x,y,z; char c1; cin>>x>>c1>>y; //c1 //多路选择语句选择不同表达式计算语句 switch(c1) { case '+':cout< float x=365.5; //声明全局变量 main() { int x=1,y=2; double w=x+y; { double x=1.414,y=1.732,z=3.14; cout<<"inner:x="<=1;j--) cout< main() { //声明数组和变量 int a[5],i,sum; double avg; //从键盘上循环为数组赋值 for (i=0;i<5;i++) { cout<<"a["<>a[i]; } 38 //直接显示数组元素 cout< main() { //声明变量 int i,j; float t,a[5]; //从键盘上为数组赋值 for (i=0;i<=4;i++) { cout<<"a["<>a[i]; } 40 //对数组按从大到小顺序排序 for (i=0;i<=3;i++) for (j=i+1;j<=4;j++) if (a[i]<=a[j]) { t=a[i]; a[i]=a[j]; a[j]=t; } //显示排序结果 for (i=0;i<=4;i++) cout< main() { //声明二维数组及变量 int a[2][3],i,j; //从键盘上为数组 a 赋值 for (i=0;i<2;i++) for (j=0;j<3;j++) { cout<<"a["<>a[i][j]; } //显示数组 a for (i=0;i<2;i++) { for (j=0;j<3;j++) { cout< main() { //声明数组、变量和指针变量 int a[]={1,2,3,4,5,6}; int *ip1,*ip2; //测试指针的赋值运算 ip1=a; ip2=ip1; cout<<"*ip1="<<(*ip1)<ip1="<=x[j]) { ft=x[i],x[i]=x[j],x[j]=ft; it=h[i],h[i]=h[j],h[j]=it; pt=p[i],p[i]=p[j],p[j]=pt; } //以下打印排序结果 for (i=0;i<=3;i++) cout< main() { //声明指针数组 char *colors[]={"Red","Blue","Yellow","Green"}; //指向指针的指针变量 char **pt; //通过指向指针的变量访问其指向的内容 pt=colors; for (int i=0;i<=3;i++) { 44 cout<<"pt="< main() { int i; //定义结构类型 struct student { int num; char name[10]; float maths; float physics; float chemistry; double total; }; //声明结构数组 st student st[3]; //从键盘上为结构数组输入值 cout<<" num name maths physics chemistry "<>st[i].num; cin>>st[i].name; cin>>st[i].maths; cin>>st[i].physics; cin>>st[i].chemistry; } //计算每个学生的总成绩 for (i=0;i<3;i++) st[i].total=st[i].maths+st[i].physics+st[i].chemistry; //输出结构数组各元素的值 for (i=0;i<3;i++) { cout<<"st["< main() { //定义结构类型 struct human { char name[10]; int sex; int age; }; //声明结构变量和结构指针变量,并初始化 struct human x={"WangPing",1,30},*p=NULL; 46 //结构指针变量指向对象 p=&x; //显示结构变量的值 cout<<"x.name="<name="<name<sex="<sex<age="<age<>(*p).name; cout<<"sex:"; cin>>(*p).sex; cout<<"age:"; cin>>(*p).age; //显示结构变量的值 cout<<"x.name="<name="; cin>>p->name; cout<<"p->sex="; cin>>p->sex; cout<<"p->age="; cin>>p->age; cout<<"-------------------------"<name="<name<sex="<sex<age="<age<name<<'\t'; cout<sex<<'\t'; cout<age< main() { //定义一个包含指针成员的结构类型 struct test { char *str; int *ip; } x; //使用结构变量 x 中的整型指针 ip x.ip=new int; //分配 1 个单元 *(x.ip)=100; cout<<"x.ip:"< main() { //定义 date 结构 struct date { int year; int month; int day; }; //定义 baby 结构 struct baby { int num; float weight; date birthday; // date为结构类型 }; //声明 baby 结构变量并初始化 baby b1={10001,10,{2002,12,25}}; //下列是 baby 结构变量 b1 的引用。 cout<<"b1.num="< main() { int i; //定义名为 student 的递归结构 struct student { char name[10]; int math; int computer; float sum; student *next; //next成员是指向自身的结构指针 }; //用 student 声明 3 个结构指针变量 struct student *head,*tail,*temp; //申请第 1 块数据,并设置各结构指针的初值 temp=new struct student; //申请内存 head=temp; // 头指针 tail=head; // 尾指针 //循环为链表输入数据 cout<<"\tname Math Computer"<>temp->name; if (temp->name[0]!='*') { cin>>temp->math>>temp->computer; temp->sum=temp->math+temp->computer; temp->next=NULL; tail=temp; //设置链表尾指针 } else 50 { // 以下是输入结束处理 delete temp; tail->next=NULL; break; } //为下一个学生申请内存 temp->next=new struct student; temp=temp->next; // 使处理指针 temp 指向新内存块 } //将链表数据从头到尾打印出来 cout<<"--------------------"<name<<","<math<<","; cout<computer<<","<sum<next; } } #include main() { int i; //定义名为 student 的递归结构 struct student { char name[10]; int math; int computer; float sum; student *forw; //forw成员是前指针 student *next; //next成员是后指针 }; //用 student 声明 3 个结构指针变量 struct student *head,*tail,*temp; //申请第 1 块数据,并设置各结构指针的初值 temp=new struct student; //申请内存 head=temp; // 头指针 tail=head; // 尾指针 head->forw=NULL; //循环为链表记录输入数据 cout<<"\tname Math Computer"<>temp->name; if (temp->name[0]!='*') { cin>>temp->math>>temp->computer; temp->sum=temp->math+temp->computer; temp->next=NULL; tail=temp; //设置链表尾指针 } else { // 以下是输入结束处理 delete temp; tail->next=NULL; 51 break; } //为下一个学生申请内存 temp->next=new struct student; temp->next->forw=temp; //设置前指针 temp=temp->next; //使处理指针 temp 指向新内存块 } // 将链表数据从头到尾打印出来 cout<<"head------>tail:"<name<<","<math<<","; cout<computer<<","<sum<next; } // 将链表数据从尾到头打印出来 cout<<"tail------>head:"<name<<","<math<<","; cout<computer<<","<sum<forw; } } #include main() { int i; //定义联合类型 union utag { char c; int k; float x; }; //声明联合变量 union utag u; // 使用联合变量中的字符型成员 u.c='*'; cout<<"u.c="< //定义结构类型 struct student { int num; char name[20]; float grade; }; void main(void) { //声明数组 int i,size; char str[]="This is a string."; 53 int int_values[] = {51, 23, 2, 44, 45,0,11}; float float_values[] = {15.1, 13.3, 22.2, 10.4, 1.5}; student st_arr[]={101,"WangLin",92,102,"LiPing",85,103,"ZhaoMin",88}; //显示 char 类型数组元素及其大小 size=sizeof(str) / sizeof(char); cout<<"Number of elements in str: "; cout< //add()函数的定义,其有返回值 double add(double x,double y) { double z; z=x+y; cout<total=p1->maths+p1->physics+p1->chemistry; } //对 3 个学生的数据排序 for (i=0;i<=2;i++) for (j=i+1;j<=2;j++) if (a[i].total //定义结构 struct student { char name[10]; float grade; }; //交换 student 类型的数据 void swap(student &x,student &y) //swap 的参数为引用传递方式 { student temp; temp=x; x=y; y=temp; } //返回 student 类型的引用,求优者 student& max(student &x,student &y) //swap 的参数为引用传递方式 { return (x.grade>y.grade?x:y); } //显示 student 类型的数据 void show(student &x) //show 的参数为引用传递方式 { cout< //参数带有默认值的函数 disp(int x=1,int y=1,int z=1) { cout<<"参数 1: "< //计算字符串长度的函数 int str_len(const char *string) { //char *temp=string; 编译报错! //*string='x'; 编译报错! int i=0; while (*(string+i)!=NULL) i++; return i; } //main()函数中测试 str_len() void main() { char a[]="ABCDE"; cout< void disp(void); //这个函数声明语句不能少 //定义 main()函数的参数和返回值类型是 void 类型 void main(void) { //调用 void 类型函数 disp(); } //以下定义 disp()函数 void disp(void) { cout<<" You are welcome."< //函数原型语句 int abs(int x); long abs(long x); float abs(float x); //main()函数的定义 void main(void) { //声明变量 int i1=32767,i2=-32767; long l1=456789,l2=-456789; float x1=1.1234,x2=-1.1234; //直接在 cout 输出中调用函数 cout< //max()为内联函数 inline int max(int x,int y) //注意 inline 关键字 { return x>y?x:y; } //定义 main()函数 main() { int a=3,b=5,c; c=max(a,b); cout<<"max("< //用函数原型声明要使用的函数 void show_array1(int*,int); void show_array2(int a[],int); void sort(int*,int); main() { //声明数组并初始化 int a[]={2,4,6,1,3,5}; int b[3][3]={{2,4,6},{1,3,5},{0,1,2}}; //显示数组的值 cout<<"show_array1(int*,int):"< //定义结构 struct student { char name[10]; float grade; }; //更改 student 数据的 grade 成员,参数形式为引用 void change(student &x,float grade) { x.grade=grade; } //更改 student 数据的 grade 成员,参数形式为指针 void change1(student *p,float grade) { p->grade=grade; } 61 //更改 student 类型的数据,普通参数形式 void change2(student x,float grade) { x.grade=grade; } //显示 student 类型的数据,参数形式为引用 void show(student &x) { cout< //定义函数计算数组的和和平均值 void calculate(int a[],int size,int& sum,float& average) { sum=0; for (int i=0;i b) ? a: b); } //计算最小值 int min(int a, int b) { cout<<"In min"<>a>>b; cout< #include #define size 3 //定义 book 结构类型 struct book { char title[20]; char author[15]; int pages; float price; }; //book 结构的输入函数 input_book(book& bk,char *name) { cout<>bk.title; cout<<"author:"; cin>>bk.author; cout<<"pages:"; cin>>bk.pages; cout<<"price:"; cin>>bk.price; } //book 结构的输出函数 output_book(book& bk,char *name) { cout< //声明全局变量并初始化 extern int a[]={1,2,3}; extern float p=3.14; //在 show()函数中使用外部变量 show() { int i; cout<<"In show():"< main() { int i,s=0; extern int fact(int x); for (i=2;i<=6;i=i+2) s+=fact(i); cout<<"s="< #include #include #include main() { //声明变量 FILE *fp1; char str[80]; //从键盘上任意输入一个字符串 cout<<"Inupt a string:"; cin.getline(str,80); //以写入方式打开 d.dat 文件 if ((fp1=fopen("d.dat","w"))==NULL) { cout<<"\nCould not open the file."< #include #include #include void main(void) { //变量声明 char ch; FILE *fp1; //以写入方式打开 d.dat 文件 if ((fp1=fopen("d.dat","w"))==NULL) { cout<<"\nCould not open the file."<>ch; while (ch!='*') { fputc(ch,fp1); //将字符写到 fp1 指向的"流"文件中 cin>>ch; } fclose(fp1); //关闭文件 // 以读方式打开 d.dat 文件 if ((fp1=fopen("d.dat","r"))==NULL) { cout<<"\nCould not open the file."< #include 67 #include #include main() { //声明变量 int i=0; char p[100]; // 声明输入缓冲区 FILE *fp1; // 声明文件指针变量 //以写入方式打开 d.dat 文件 if ((fp1=fopen("d.dat","w"))==NULL) { cout<<"\nCould not open the file."<>p; //从键盘上输入数据 if (stricmp(p,"end")) { //如果输入的字符串为 end,则结束循环 fputs(p,fp1); //写入文件操作 fputs("\n",fp1); } else break; //退出循环 } fclose(fp1); //关闭文件 // 以读方式打开 d.dat 文件 if ((fp1=fopen("d.dat","r"))==NULL) { cout<<"\nCould not open the file."< #include #include #include #include #define MAX 10 main() { //声明变量 int i,n; FILE *fp1; // 声明文件指针变量 //以写入方式打开 d.dat 文件 if ((fp1=fopen("d.dat","w"))==NULL) { cout<<"\nCould not open the file."< #include #include #include #include #define MAX 3 main() { //定义结构类型 struct student { int num; char name[10]; float grade; }; //声明数组和变量 student st[3]; int i; FILE *fp1; // 声明文件指针变量 //以写入方式打开 d.dat 文件 if ((fp1=fopen("d.dat","w"))==NULL) { cout<<"\nCould not open the file."<>st[i].num; cin>>st[i].name; cin>>st[i].grade; 69 fprintf(fp1,"%d %s %f\n",st[i].num,st[i].name,st[i].grade); } fclose(fp1); //关闭文件 // 以读方式打开 d.dat 文件 if ((fp1=fopen("d.dat","r"))==NULL) { cout<<"\nCould not open the file."< #include #include #include int main(void) { FILE *fpd,*fpw; // 声明 FILE 结构指针变量 unsigned char dw; int i=0; //以二进制读方式打开 Calc.exe 文件 if((fpd=fopen("C:\WINDOWS\Calc.exe", "rb"))==NULL) { cout<<"\nCould not open the file."< #include #include #include void main(void) { //声明变量 int i; char ch; FILE *fp1; //以写入方式打开 d.dat 文件 if ((fp1=fopen("d.dat","w"))==NULL) { cout<<"\nCould not open the file."<>ch; while (ch!='*') { fputc(ch,fp1); //将字符写到 fp1 指向的"流"文件中 cin>>ch; } cout<<"--------------------"< #include #include #include #define MAX 5 //显示数组的数据 void show_array(double x[],int size) { for(int i=0;i #include #include #include #define MAX 5 //定义结构类型 struct student { int num; char name[20]; float grade; }; //显示 student 结构数据 void show_str(student a,char *name) { cout< #include #include int main(void) { //声明变量 char ch; char str[20]; int n; float x; //用 stdin 从键盘上输入数据 fprintf(stdout,"ch str\n"); fscanf(stdin,"%c %s",&ch,str); 74 fprintf(stdout,"n x \n"); fscanf(stdin,"%d %f",&n,&x); cout<<"----------------"< void main( void ) { int c; /* Create an error by writing to standard input. */ putc( 'A', stdin ); if( ferror( stdin ) ) { perror( "Write error" ); clearerr( stdin ); } /* See if read causes an error. */ printf( "Will input cause an error? " ); c = getc( stdin ); if( ferror( stdin ) ) { perror( "Read error" ); clearerr( stdin ); } } #include #include //此预处理指令不可少 const double HD=3.1415926/180; main() { cout<<"x\tsin(x)"< //以下是几个简单宏替换预处理指令 #define YES 1 #define PI 3.1415926 #define RAD PI/180 #define MESG "This is a string." //以下是主程序 main() { //以下各语句使用了宏替换 cout<<"YES="<>x; b.push(x); } //以下利用循环和 pop()成员函数依次弹出 b 栈中的数据并显示 for (i=1; i<=MAX; i++) cout< const int MAX=5; //假定栈中最多保存 5 个数据 //定义名为 stack 的具有栈功能的类 class stack { //数据成员 float num[MAX]; //存放栈数据的数组 int top; //指示栈顶位置的变量 public: //成员函数 stack(void) //初始化函数 { top=0; cout<<"Stack initialized."<>x; b.push(x); } //以下利用循环和 pop()成员函数依次弹出 b 栈中的数据并显示 for (i=1; i<=MAX; i++) cout< const int MAX=5; //假定栈中最多保存 5 个数据 //定义名为 stack 的具有栈功能的类 class stack { //数据成员 float num[MAX]; //存放栈数据的数组 int top; //指示栈顶位置的变量 public: //成员函数 stack(char c) //初始化函数 { top=0; cout<<"Stack "< main() { //定义一个名为 student 的类 class student { int num; char *name; float grade; public: //定义构造函数 student(int n,char *p,float g): num(n),name(p),grade(g){} display(void) { cout< #include //定义 timer 类 class timer{ long minutes; public: //无参数构造函数 timer(void) { minutes =0; }; //字符指针参数的构造函数 79 timer(char *m) { minutes = atoi(m); }; //整数类型的构造函数 timer(int h, int m) { minutes = 60*h+m ; }; //双精度浮点型构造函数 timer(double h) { minutes = (int) 60*h ; }; long getminutes(void) { return minutes ; }; }; //main()函数的定义 main(void) { //使用 double 类型的构造函数创建对象 timer start(8.30),finish(17.30); cout<<"finish(17.30)-start(8.30)="; cout< const int MAX=5; //假定栈中最多保存 5 个数据 //定义名为 stack 的具有栈功能的类 class stack { //数据成员 double num[MAX]; //存放栈数据的数组 int top; //指示栈顶位置的变量 public: //成员函数 stack(char *name) //构造函数 { top=0; cout<<"Stack "<>x; b.push(x); } cout<<"b: "; for(i=1;i<=MAX;i++) cout< #define MAX 5 //定义 stack 类接口 class stack{ int num[MAX]; int top; public: stack(char *name); //构造函数原型 ~stack(void); //析构函数原型 void push(int n); int pop(void); }; //main()函数测试 stack 类 main(void) { int i,n; //声明对象 stack a("a"),b("b"); //以下利用循环和 push()成员函数将 2,4,6,8,10 依次入 a 栈 for (i=1; i<=MAX; i++) a.push(2*i); //以下利用循环和 pop()成员函数依次弹出 a 栈中的数据,并显示 cout<<"a: "; for (i=1; i<=MAX; i++) cout<>n; b.push(n); } cout<<"b: "; for(i=1;i<=MAX;i++) cout< //定义一个全部为 public:模式的类 class ex { public: int value; void set(int n) { value=n; } int get(void) { return value; } }; //测试使用 ex 类 main() { ex a; //创建对象 //以下通过成员函数访问对象数据 a.set(100); cout<<"a.get()="; cout< //定义一个含有 static 数据成员的类 class ex { static int num; //static数据成员 public: ex() {num++;} ~ex() {num--;} disp_count() { cout<<"The current instances count:"; cout<disp_count(); ex x[10]; x[0].disp_count(); delete p; a.disp_count(); } #include //定义一个含有 static 数据成员的类 class ex { static int num; //static数据成员 public: ex() {num++;} ~ex() {num--;} static disp_count(void) //static 成员函数 { cout<<"The current instances count:"; cout<disp_count(); ex x[10]; ex::disp_count(); //直接用类作用域符引用静态成员函数 delete p; ex::disp_count(); //直接用类作用域符引用静态成员函数 } #include class ex_class { int value; public: ex_class(int n) { value=n; cout << "Stack initialized." << endl; } ~ex_class() { cout << "The Object destroyed." < //定义空类 empty class empty { }; //在 main()函数中用空类创建对象 main() { empty a,*p; //编译通过 cout<<"Test a empty class."< //用 struct 关键字定义 ex_class 类 struct ex_class { ex_class(int n=1): value(n) {} void set_value(int n) { value=n; } show_obj(char *name) { cout< #include //定义双亲(parent)类 class parent { char f_name[20]; char m_name[20]; char tel[10]; public: // parent类的构造函数,其带有缺省值 parent(char *p1="",char *p2="",char *p3="") { strcpy(f_name,p1); strcpy(m_name,p2); strcpy(tel,p3); } //显示 parent 对象的数据 show_parent(void) { cout<<"The parent:"< #include //定义 timer 类 class timer{ long minutes; public: //定义重载成员函数 settimer(char *m) { minutes = atoi(m); }; //定义重载成员函数 settimer(int h, int m) { minutes = 60*h+m ; }; //定义重载成员函数 settimer(double h) { minutes = (int) 60*h ; }; long getminutes(void) { return minutes; }; }; //main()函数的定义 main(void){ timer start,finish; //创建对象 //使用重载成员函数 start.settimer(8,30); finish.settimer(9,40); cout<<"finish.settimer(9,40)-start.settimer(8,30):"; cout< //定义复数类 class complex{ float real; //实部 float image; //虚部 public: //重载的运算符"+"的原型 complex operator+ (complex right); //重载赋值运算符"="的定义 complex operator= (complex right); void set_complex(float re, float im); void put_complex(char *name); }; 88 //重载加法运算符"+"的定义 complex complex::operator+ (complex right) { complex temp; temp.real = this->real + right.real; temp.image = this->image + right.image; return temp; } //重载加赋值运算符"="的定义 complex complex::operator= (complex right) { this->real = right.real; this->image = right.image; return *this; } //定义 set_complex()成员函数 void complex::set_complex(float re, float im) { real = re; image = im; } //定义 put_complex()成员函数 void complex::put_complex(char *name) { cout<= 0.0 ) cout << '+'; cout << image << "i\n"; } //在 main()函数中使用 complex 类的对象 main(void) { complex A, B, C; //创建复数对象 //设置复数变量的值 A.set_complex(1.2, 0.3); B.set_complex(-0.5, -0.8); //显示复数数据 A.put_complex("A"); B.put_complex("B"); //赋值运算,显示结果 C = A; C.put_complex("C=A"); //加法及赋值运算,显示结果 C = A + B; C.put_complex("C=A+B"); return 0; } // Example of the friend class #include //定义 YourClass 类, class YourClass { //指定 YourOtherClass 是它的友元类 friend class YourOtherClass; private: int num; public: YourClass(int n){num=n;} display(char *YCname){ cout< //Y 类的不完全定义 class Y; //X 类的定义 class X { public: void disp(Y py,char *name); //成员函数原型 }; //定义 Y 类 class Y { //声明本类的友元函数 //X类的 disp()为本例的友元函数 friend void X::disp(Y py,char *name); //普通函数 putY() 为本例的友元函数 friend void putY(Y& yc,char *name); private: //私有成员 int num; dispY(char *name){ cout< //定义日期类 class Date { //定义友元重载输入运算符函数 friend istream& operator >> (istream& input,Date& dt ); //定义友元重载输出运算符函数 friend ostream& operator<< (ostream& output,Date& dt ); int mo, da, yr; public: Date(void){ //无参数构造函数 yr = 0; mo = 0; da = 0; } Date( int y, int m, int d ) //带参数构造函数 { yr = y; mo = m; da = d; } }; //定义">>"运算符重载函数 91 istream& operator >> ( istream& input, Date& dt ) { cout<<"Year:"; input>>dt.yr; cout<<"Month:"; input>>dt.mo; cout<<"Day:"; input>>dt.da; return input; } //定义"<<"运算符重载函数 ostream& operator<< ( ostream& output, Date& dt ) { output<< dt.yr << '/' << dt.mo << '/' << dt.da<>)运算符 void main() { //声明对象 Date dt1(2002,5,1),dt2; //显示 dt1 对象 cout<>dt2; cout< //定义 ex 类 class ex_class { int a; double b; public: ex_class(int n=1,double x=1.0):a(n),b(x) {} void show_value(char *name) { cout<show_value("p->obj1"); 92 //p指向 obj2 并显示 p=&obj2; (*p).show_value("(*p)obj2"); //p指向动态创建的对象并显示 p=new ex_class; p->show_value("p->new"); delete p; //删除对象 } #include //基类 Box class Box { int width,height; public: void SetWidth(int w) { width=w; } void SetHeight(int h) { height=h; } int GetWidth() {return width;} int GetHeight() {return height;} }; //派生类 ColoredBox class ColoredBox:public Box { int color; public: void SetColor(int c){ color=c; } int GetColor() {return color;} }; // 在 main()中测试基类和派生类 main(void) { //声明并使用 ColoredBox 类的对象 ColoredBox cbox; cbox.SetColor(3); //使用自己的成员函数 cbox.SetWidth(150); //使用基类的成员函数 cbox.SetHeight(100); //使用基类的成员函数 cout<<"cbox:"< //基类 First class First { int val1; public: SetVal1(int v) { val1=v; } void show_First(void) { 93 cout<<"val1="< //定义最低层基类,它作为其他类的基类 class First { int val1; public: First(void) { cout<<"The First initialized"< //定义基类 First class First { int num; float grade; public: //构造函数带参数 First(int n,float v ) : num(n),grade(v) { cout<<"The First initialized"< //定义最低层基类 First,它作为其他类的基类 class First { int val1; public: First() { cout<<"The First initialized"< //基类 class First { int val1; protected: void SetVal1(int v) { val1=v; } public: show_First(void) { cout<<"val1="< enum Color {Red,Yellow,Green,White}; //圆类 Circle 的定义 class Circle { float radius; public: Circle(float r) {radius=r;} float Area() { return 3.1416*radius*radius; } }; //桌子类 Table 的定义 class Table { float height; public: Table(float h) {height=h;} float Height() { return height; } }; //圆桌类 RoundTable 的定义 class RoundTable:public Table,public Circle { Color color; public: RoundTable(float h,float r,Color c); //构造函数 int GetColor() { return color; } }; //圆桌构造函数的定义 RoundTable::RoundTable(float h,float r,Color c):Table(h),Circle(r) { color=c; } //main()函数的定义 main() { RoundTable cir_table(15.0,2.0,Yellow); cout<<"The table properties are:"< //定义抽象类 class Base { public: //定义两个纯虚函数 virtual void aFn1(void)=0; virtual void aFn2(void)=0; }; //派生类 Derived_1 中覆盖了基类中的纯虚函数 class Derived_1:public Base { public: void aFn1(void) { cout<<"aFnl is in First derived class."< int extract_int() { char ch; int n=0; while(ch=cin.get()) if (ch>='0' && ch<='9') { cin.putback(ch); cin>>n; break; } return n; } //main()函数 main(void) { //提取字符串中的数字 int a=extract_int(); int b=extract_int(); int c=extract_int(); //显示结果 cout< //定义节点(数据对象)的接口 class Node { //声明 list 类为本类的友元类 friend class list; //私有成员 private: int Data; //节点数据 Node *previous; //前趋指针 Node *next; //后继指针 }; //定义双向链表 list 的接口声明 class list { //私有成员 private: Node *Head; //链表头指针 Node *Tail; //链表尾指针 //定义接口函数 public: //构造函数 list(); //析构函数 ~list(); //从链表尾后添加数据 void Build_HT(int Data); //从链表前头添加数据 void Build_TH(int Data); //从头到尾显示数据 void list::Display_HT(); 102 //从尾到头显示数据 void list::Display_TH(); //清除链表的全部数据 void Clear(); }; //main()函数测试双向链表 int main(void) { list list1; int i; //从尾添加数据 cout<<"Add to the back of the list1:"<Data=Data; if(Head==0) { Head=Buffer; Head->next=0; Head->previous=0; Tail=Head; 103 } else { Tail->next=Buffer; Buffer->previous=Tail; Buffer->next=0; Tail=Buffer; } } //从链表前头添加数据 void list::Build_TH(int Data) { Node *NewNode; NewNode=new Node; NewNode->Data=Data; if(Tail==0) { Tail=NewNode; Tail->next=0; Tail->previous=0; Head=Tail; } else { NewNode->previous=0; NewNode->next=Head; Head->previous=NewNode; Head=NewNode; } } //从头到尾显示数据 void list::Display_HT() { Node *TEMP; TEMP=Head; cout<<"Display the list from Head to Tail:"<Data<<" "; TEMP=TEMP->next; } cout<Data<<" "; TEMP=TEMP->previous; } cout<next; delete TEMP_NODE; } while (Temp_head!=0); } #include #include using namespace std; //测试字符串(string)对象 void main() { //创建 string 对象,并显示 string s1; string s2="ABCDEFGHIJK"; string s3=s2; string s4(20,'A'); string s5(s2,3,3); cout<<"s1="< "<=s2) //大于等于 cout<= "< const float PI=3.1416; //声明常量(只读变量)PI 为 3.1416 float fCir_L(float); //声明自定义函数 fCir_L()的原型 float fCir_S(float); //声明自定义函数 fCir_S()的原型 //以下是 main()函数 main() { float r,l,s; //声明 3 个变量 cout<<"R="; //显示字符串 cin>>r; //键盘输入 l=fCir_L(r); //计算圆的周长,赋值给变量 l s=fCir_S(r); //计算圆的面积,赋值给变量 s cout<<"l="<>n; 107 //将整型数 n 按十进制转换为字符串并输出 p=itoa(n,str,10); cout<<"str="<>str; int n=atoi(str); cout<<"n="<>str; double x=atof(str); cout<<"x="< #include #include //定义产生[n1,n2]范围 int 随机数的函数 int rand(int n1,int n2) { if (n1>n2) return -1; if (n1==n2) return 0; int temp=n1+int((n2-n1)*double(rand())/RAND_MAX); return temp; } 108 //main()函数的定义,加法练习程序 void main( void ) { int i; //使用当前的系统时间初始化随机数种子 srand( (unsigned)time( NULL ) ); //加法练习 int a,b,c; do { a=rand(0,20); b=rand(0,20); L1: cout<>c; if (c==0) break; if (c!=a+b) { cout<<"Error! Try again!"< #include #include #define PI 3.1415926535 //main()函数的定义 void main( void ) { int i; double x=PI/180; cout<<"X\tSIN(X)\t\tCOS(X)"< #include #include #define PI 3.1415926535 //main()函数的定义 void main( void ) { int i; double d=180/PI; cout<<"X\tASIN(X)\t\tACOS(X)"< #include #include //main()函数的定义 void main( void ) { _complex a={3,4},b={3,-4}; double d=cabs(a); cout<<"cabs("< #include //main()函数的定义 void main(void) { //声明 time_t 类型的变量,其以秒为单位存放系统时间 time_t current_time; //得到当前的系统时间(秒) time(¤t_time); //转换系统时间为 tm 结构的时间信息 tm *ptime=gmtime(¤t_time); 111 //显示 time_t 结构的时间 cout<<"current_time:"<tm_sec)<tm_min)<tm_hour)<tm_mday)<tm_mon)<tm_year)<tm_wday)<tm_yday)<tm_isdst)< #include //main()函数的定义 void main(void) { //声明变量 time_t current_time; //得到当前系统时间 time(¤t_time); //转换系统时间为 tm 结构 tm *ptime=gmtime(¤t_time); //转换 time_t 类型的时间字符串并显示 char *timep=ctime(¤t_time); cout<<"ctime(¤t_time):"< #include #include //定义时间延迟函数 void Dtime(double dt) { time_t current_time; time_t start_time; //得到开始时间 time(&start_time); //延迟处理 do { time(¤t_time); } while (difftime(current_time,start_time) #include #include int main(void) { //定义结构类型 struct student { int num; char name[20]; float grade; }; //声明结构指针变量 struct student *sp; //计算申请的内存量 int size=sizeof(struct student); //申请需要的存储空间并强制类型转换 sp=(struct student*)malloc(size); //为结构对象输入数据 cout<<"nmu:"; cin>>(sp->num); cout<<"name:"; cin>>(sp->name); cout<<"grade:"; cin>>(sp->grade); //输出结构对象的数据 cout<<"num:"<<(sp->num)<name)<grade); //释放内存 free(sp); } #include #include #include //定义时间延迟函数 void Dtime(double dt) { time_t current_time; time_t start_time; // 得到开始时间 time(&start_time); 113 //延迟处理 do { time(¤t_time); } while (difftime(current_time,start_time) main() { //输出字符串 printf("He said \"Hello!\""); //输出各进制整数 int i=64; printf("\ni=%d",i); //以十进制格式输出 printf("\ni=%o",i); //以八进制格式输出 printf("\ni=%x",i); //以十六进制格式输出 printf("\ni=%d,%o,%x",i,i,i); //各种格式混合输出 //输出浮点数 float x=3141.5926; printf("\nx=%f",x); //指定输出浮点数的格式为十进制形式 printf("\nx=%e",x); //指定输出浮点数的格式为指数形式 114 //控制输出项宽度 int j=123; printf("\nj=%-10d",j); //任选项"-"指定左对齐,W 指定宽度为 10 printf("\nj=%10d\n",j); //W 指定宽度为 10 //控制输出精度 float y=3.1415926; printf("y=%10.2f\n",y); //W 指定宽度为 10,P 指定小数点后保留 2 位 printf("y=%10.5f\n",y); //W 指定宽度为 10,P 指定小数点后保留 5 位 } #include main() { //输入字符串 char str[80]; printf("str:"); //显示提示 scanf("%s",str); printf("The string:%s",str); //输入各进制整数 int a,b,c,sum; printf("\na\tb\tc\n"); //显示提示 scanf("%d %o %x",&a,&b,&c); //以十进制、八进制、十六进制形式输入数据 sum=a+b+c; printf("a=%d b=%d c=%d sum=%d",a,b,c,sum); //输入浮点数并计算显示 float x,y; //声明变量 printf("\nx\ty\n"); //显示提示 scanf("%f %f",&x,&y); //对非空白字符"x= y="读入,不保存 printf("sum=%f product=%f\n",x+y, x*y); //显示表达式的值 } #include #include #include #define MAX_PATH 250 main() { //声明变量 char *p,str[MAX_PATH]; //设置新目录 if (mkdir("d:\\ABC")){ cout<<"mkdir Error!"< #include #include #include #include void main( void ) { struct stat buf; int result; //获得 c:\Windows\Calc.exe 文件的状态信息 result =stat( "c:\\windows\\Calc.exe", &buf ); //显示 Calc.exe 文件的状态信息 if( result != 0 ) perror( "Problem getting information" ); else { cout<<"Size of the file in bytes:"< #include void main( void ) { //设置字符串 char string[] = "Fill the string with something"; cout<<"string:"< #include void main( void ) 116 { //拷贝字符串常量到字符数组 char string[80] = "Fill the string with something"; cout<<"string:"<>str; p=strcpy(string,str); cout<<"p :"<>str; cout<<"strncpy:"< #include void main( void ) { //声明字符数组和字符型指针变量 char string[80],*p; //拷贝字符串 strcpy( string, "I'll see you"); cout<<"string:"< #include //字符串输入函数 void str_input(char *p1,char *p2) { cout<<"string1:"; cin>>p1; cout<<"string2:"; cin>>p2; } //显示 strcmp()函数的比较结果 void strcmp_put(char *p1,char *p2) { cout<<"strcmp():"<0) cout<0) cout<0) cout< #include //main()函数 void main( void ) { //声明字符数组 char string[80],*p; int i; //转换字符串中的小写字母为大写 cout<<"Convert a string to uppercase:"<>string; p=strupr(string); cout<<"p:"<>string; p=strlwr(string); cout<<"p:"< #include //main()函数 void main( void ) { //声明字符数组 char string[]="This is a test."; int n; //获得字符串的长度 cout<<"string:"<>string; n=strlen(string); cout<<"The length of "<<"\""< #include //main()函数 void main( void ) { //声明字符数组 char ch,string[80],*p; int n; //输入字符串和要查找的字符 cout<<"Test strchr():"<>string; cout<<"ch :"; cin>>ch; //在 string 中查找 ch 中的字符并显示 p=strchr(string,ch); cout<<"p :"<>substr; //在 string 中查找 substr 中的字符串并显示 p=strstr(string,substr); cout<<"p :"< #include //main()函数 void main( void ) { //声明字符数组 char string[80],*p; //输入字符串并将其反转 cout<<"string:"; cin>>string; p=strrev(string ); cout<<"p :"< #include char string[80]; char seps[] = " ,\t\n"; char *token; void main( void ) { //从键盘上输入两个语句 for (int i=1;i<3;i++) { cout<<"Please input a sentence:"< #include #include //main()函数 void main( void ) { //声明变量和数组 char buffer[200], s[] = "computer", c = 'l'; int i = 35, j; float fp = 1.7320534f; //格式化输出到 buffer 120 j = sprintf( buffer, "\tString: %s\n", s ); j += sprintf( buffer + j, "\tCharacter: %c\n", c ); j += sprintf( buffer + j, "\tInteger: %d\n", i ); j += sprintf( buffer + j, "\tReal: %f\n", fp ); cout<<"Output:"< void display(T1 x, T2 y) { cout << x << " " << y << endl; } 122 #include //声明引用参数的函数模板原型 template void swap(T &x, T &y); //定义一个结构类型 struct student { int n; char name[20]; float grade; }; //在 main()函数中测试 swap()函数模板 void main(void) { //交换两个 int 型变量中的数据 int m=3,n=5; cout<<"m="< void swap(T &x, T &y) { T temp; temp=x; x=y; y=temp; } #include 123 //声明函数模板的原型语句 template void swap(T *x, T *y); //定义一个结构类型 struct student { int n; char name[20]; float grade; }; //在 main()函数中测试 swap()函数模板 void main(void) { //交换两个 int 型变量中的数据 int m=3,n=5; cout<<"m="< void swap(T *x, T *y) { T temp; temp=*x; *x=*y; *y=temp; } #include 124 //定义输入函数模板 template void input(char *str,T &x) { cout<>x; } //定义输出函数模板 template void output(char *str,T x) { cout< #include //显示数组的函数模板 template void arr_put(T arr[],int size) { for (int i=0 ;i<=size;i++) cout< void sort(T arr[],int size) { T temp; int i,j; for (i=0;i>str; int size=strlen(str); arr_put(str,size); sort(str,size); arr_put(str,size); } #include #include //显示数组的函数模板 template void arr_put(T arr[],int size) { for (int i=0 ;i void sort(T arr[],int size) { T temp; int i,j; for (i=0;iarr[j]) { temp=arr[i]; arr[i]=arr[j]; arr[j]=temp; } } //二分查找法的函数模板 template int binary_search(T array[], T value, int size) 126 { int found = 0; int high = size, low = 0, mid; mid = (high + low) / 2; cout<<"Looking for "<= low)) { if (value == array[mid]) found = 1; else if (value < array[mid]) high = mid - 1; else low = mid + 1; mid = (high + low) / 2; } return((found) ? mid: -1); } //main()函数中使用处理数组的函数模板 void main(void) { //处理 int 型数组 int array[10]={1,3,5,7,9,2,4,6,8,10}; //显示数组初值 arr_put(array,10); //对数组排序并显示 sort(array,10); arr_put(array,10); //查找数组 cout<<"Result of search: "<>ch1; cout<<"Result of search: "< //定义名为 ex_class 的类模板 template class ex_class 127 { T value; public: ex_class(T v) { value=v; } void set_value(T v) { value=v; } T get_value(void) {return value;} }; //main()函数中测试 ex_class 类模板 void main(void) { //测试 int 类型数据 ex_class a(5),b(10); cout<<"a.value:"< ch('A'); cout<<"ch.value:"< x(5.5); cout<<"x.value:"< //定义栈的尺寸 const int SIZE = 100; //定义处理栈的类模板接口 template class stack { T stck[SIZE]; int tos; public: stack(void) { tos = 0; cout << "Stack Initialized." << endl; } ~stack(void) { cout << "Stack Destroyed." << endl; } void push(T); T pop(void); }; //定义栈的成员函数 template void stack::push(T i) { if(tos==SIZE) { cout << "Stack is full." << endl; return; } stck[tos++] = i; } template T stack::pop(void) { 128 if(tos==0) { cout << "Stack underflow." << endl; return 0; } return stck[--tos]; } //main()函数中测试 stack 类模板 void main(void) { //处理 int 类型数据的栈 cout<<"stack a :"< a; a.push(1); a.push(2); cout << a.pop() << " "; cout << a.pop() << endl; //处理 double 类型数据的栈 cout<<"stack b :"< b; b.push(99.3); b.push(-12.23); cout << b.pop() << " "; cout << b.pop() < c :"< c; for(int i=0; i<10; i++) c.push((char) 'A' + i); for(i=0; i<10; i++) cout < //定义名为 ex_class 的类模板 template class ex_class { T1 value1; T2 value2; public: ex_class(T1 v1,T2 v2) { value1=v1; value2=v2; } void set_value(T1 v1,T2 v2) { value1=v1; value2=v2; } void put_value(void) { cout<<"valu1="< a:"< b(0.5,5); cout<<"ex_class b:"< c('a',5); cout<<"ex_class c:"< d(5,10); cout<<"ex_class d:"< #include #include #include using namespace std; //创建一个 list 容器的实例 LISTINT typedef list LISTINT; //创建一个 list 容器的实例 LISTCHAR typedef list LISTCHAR; void main(void) { //-------------------------- //用 list 容器处理整型数据 //-------------------------- //用 LISTINT 创建一个名为 listOne 的 list 对象 LISTINT listOne; //声明 i 为迭代器 LISTINT::iterator i; //从前面向 listOne 容器中添加数据 listOne.push_front (2); listOne.push_front (1); //从后面向 listOne 容器中添加数据 listOne.push_back (3); listOne.push_back (4); 130 //从前向后显示 listOne 中的数据 cout<<"listOne.begin()--- listOne.end():"< #include using namespace std; typedef vector INTVECTOR; //测试 vector 容器的功能 void main(void) { //vec1对象初始为空 INTVECTOR vec1; //vec2对象最初有 10 个值为 6 的元素 INTVECTOR vec2(10,6); //vec3对象最初有 3 个值为 6 的元素 131 INTVECTOR vec3(vec2.begin(),vec2.begin()+3); //声明一个名为 i 的双向迭代器 INTVECTOR::iterator i; //从前向后显示 vec1 中的数据 cout<<"vec1.begin()--vec1.end():"< #include using namespace std; typedef deque INTDEQUE; //从前向后显示 deque 队列的全部元素 void put_deque(INTDEQUE deque, char *name) { INTDEQUE::iterator pdeque; cout << "The contents of " << name << " : "; for(pdeque = deque.begin(); pdeque != deque.end(); pdeque++) cout << *pdeque << " "; cout< #include using namespace std; typedef list INTLIST; //从前向后显示 list 队列的全部元素 void put_list(INTLIST list, char *name) { INTLIST::iterator plist; cout << "The contents of " << name << " : "; for(plist = list.begin(); plist != list.end(); plist++) cout << *plist << " "; cout<list3: "<<(list1>list3)< #include using namespace std; //创建 set 模板的实例 typedef set SET_INT; //put_HTset 函数,从头向尾显示 set 容器的所有元素 void put_HTset(SET_INT set1,char *name) { SET_INT::iterator it; cout<s2 = "<<(s1>s2)< #include using namespace std; //创建 multiset 模板的实例 typedef multiset MULTISET_INT; //put_HTset 函数,从头向尾显示 multiset 容器的所有元素 void put_HTset(MULTISET_INT set1,char *name) { MULTISET_INT::iterator it; cout<s2 = "<<(s1>s2)< #include #include using namespace std; //创建 map 的实例,整数(int)映射字符串(string) typedef map INT2STRING; //测试 map 容器 void main() { //创建 map 对象 theMap INT2STRING theMap; INT2STRING::iterator theIterator,it; //向 theMap 容器中添入数据,数字和字符串配对 //每个元素是一个映射对 theMap.insert(INT2STRING::value_type(0,"Zero")); theMap.insert(INT2STRING::value_type(2,"Two")); theMap.insert(INT2STRING::value_type(4,"Four")); theMap.insert(INT2STRING::value_type(6,"Six")); theMap.insert(INT2STRING::value_type(8,"Eight")); //显示 map 容器的所有对象 cout<<"theMap.begin()--theMap.end():"<> theString; if(theString == "q") break; for(index = 0; index < theString.length(); index++){ theIterator = theMap.find(theString[index] - '0'); if(theIterator != theMap.end() ) cout << (*theIterator).second << " "; else cout << "[err] "; } cout << endl; } } #include #include #include using namespace std; //创建 multimap 的实例,整数(int)映射字符串(string) typedef multimap INT2STRING; //测试 multimap 容器 void main() { //创建 multimap 对象 theMap INT2STRING theMap; INT2STRING::iterator theIterator,it; //向 theMap 容器中添入数据,数字和字符串配对 //每个元素是一个映射对 theMap.insert(INT2STRING::value_type(90,"张卫")); theMap.insert(INT2STRING::value_type(85,"李华")); theMap.insert(INT2STRING::value_type(73,"赵明")); theMap.insert(INT2STRING::value_type(96,"郝名")); //显示 multimap 容器的所有对象 cout<<"theMap.begin()--theMap.end():"< #include #include using namespace std; #define ARRAY_SIZE 3 //array size //测试 valarray 容器 void main() { //创建具有 3 个元素的数组 val_array valarray val_array(ARRAY_SIZE); //设置数组的值为 1, 4, 9 for (int i = 0; i < ARRAY_SIZE; i++) val_array[i] = (i+1) * (i+1); //显示 val_array 数组的大小 cout << "Size of val_array = " << val_array.size() << endl; // 显示 val_array 数组的值 cout << "The values in val_array before calling sqrt() and pow():" << endl; for (i = 0; i < ARRAY_SIZE; i++) cout << val_array[i] << " "; 141 cout << endl; //声明一个 rev_valarray 数组,其保存对数组 val_array 的取反 valarray rev_valarray(ARRAY_SIZE); for (i = 0; i < ARRAY_SIZE; i++) rev_valarray[i] = val_array[ARRAY_SIZE - i - 1]; //显示 rev_valarray 数组的大小和元素 cout << "Size of rev_valarray = " << rev_valarray.size() << endl; cout << "The values in rev_valarray:" << endl; for (i = 0; i < ARRAY_SIZE; i++) cout << rev_valarray[i] << " "; cout < rvalue_array; //调用 sqrt()函数并显示结果 rvalue_array = sqrt(val_array); cout << "The result of rvalue_array after calling sqrt():" << endl; for (i = 0; i < ARRAY_SIZE; i++) cout << rvalue_array[i] << " "; cout < #include #include using namespace std; //创建一个 list 容器的实例 LISTINT,其存放 int 型数据 typedef list LISTINT; void main(void) { //用 LISTINT 创建一个名为 listOne 的 list 对象 LISTINT listOne; //指定 i 为迭代器变量 LISTINT::iterator i; LISTINT::reverse_iterator ir; //从前面向 listOne 容器中添加数据 listOne.push_front (2); listOne.push_front (1); //从后面向 listOne 容器中添加数据 listOne.push_back (3); listOne.push_back (4); //从前向后显示 listOne 中的数据 143 for (i = listOne.begin(); i != listOne.end(); ++i) cout << *i << " "; cout << endl; //从后向后显示 listOne 中的数据 for (ir =listOne.rbegin();ir!=listOne.rend(); ++ir) cout << *ir << " "; cout << endl; //从键盘上输入数据 for (i = listOne.begin(); i != listOne.end(); ++i) { cout<<"listOne :"; cin>>(*i); } //从前向后显示 listOne 中的数据 for (i = listOne.begin(); i != listOne.end(); ++i) cout << *i << " "; cout << endl; //bidirectional 迭代器不允许加减运算 // i=listOne.begin()+1; } #include #include #include #include #include #include using namespace std; //利用类模板生成类实例 typedef vector < int > IntArray; typedef list LISTINT; typedef set SET_INT; int add(int a, int b) { return a+b; } //在 main()函数中测试 accumulate 算法 void main () { //-------------------------------------------- // accumulate 算法对于普通数组的计算 //--------------------------------------------- int x[]={1,3,5,7,9}; cout<<"x[]:"; for (int i=0;i<5;i++) cout< StringVector ; //定义迭代器类型 147 typedef StringVector::iterator StringVectorIt ; //声明 vector 容器的对象 StringVector NamesVect(VECTOR_SIZE) ; //声明迭代器 StringVectorIt start, end, it ; int result = 0 ; // 存放统计数据 //初始化 vector 容器 NamesVect NamesVect[0] = "She" ; NamesVect[1] = "Sells" ; NamesVect[2] = "Sea" ; NamesVect[3] = "Shells" ; NamesVect[4] = "by" ; NamesVect[5] = "the" ; NamesVect[6] = "Sea" ; NamesVect[7] = "Shore" ; //设置容器的起始位置和终止位置 start = NamesVect.begin() ; end = NamesVect.end() ; //显示 NamesVect 容器的元素 cout << "NamesVect: " ; for(it = start; it != end; it++) cout << *it << " " ; cout < #include #include #define ARRAY_SIZE 10 using namespace std; //利用类模板生成实例 typedef vector < int > IntArray; //显示数组 void put_array(int x[],int size) { for(int i=0;i #include #include #define ARRAY_SIZE 10 using namespace std; //利用类模板生成实例 typedef vector < int > IntArray; //显示数组 void put_array(int x[],int size) { for(int i=0;i #include #include using namespace std; //返回一个 Fibonacci 数,其由 generate_n()算法调用 int Fibonacci1(void) { static int r; static int f1 = 0; static int f2 = 1; r = f1 + f2 ; 152 f1 = f2 ; f2 = r ; return f1 ; } //返回一个 Fibonacci 数,其由 generate()算法调用 int Fibonacci2(void) { static int r; static int f1 = 0; static int f2 = 1; r = f1 + f2 ; f1 = f2 ; f2 = r ; return f1 ; } //定义整型数的 vector 容器类 typedef vector IntVector ; //显示 vector 容器中的元素 void put_vector(IntVector v,char *name) { IntVector::iterator theIterator; cout< #include #include using namespace std; //利用类模板生成实例 typedef vector < int > IntArray; //显示数组 void put_array(int x[],int size) { for(int i=0;i #include #include #include #define ARRAY_SIZE 15 using namespace std; //定义整型数的 vector 容器类 typedef vector IntVector ; //显示数组 void put_array(int x[],int size) { for(int i=0;i #include #include #include #define ARRAY_SIZE 15 using namespace std; //显示数组 void put_array(int x[],int size) { for(int i=0;i...
还剩155页未读

继续阅读

下载pdf到电脑,查找使用更方便

pdf的实际排版效果,会与网站的显示效果略有不同!!

需要 8 金币 [ 分享pdf获得金币 ] 0 人已下载

下载pdf

pdf贡献者

pc6c

贡献于2013-09-04

下载需要 8 金币 [金币充值 ]
亲,您也可以通过 分享原创pdf 来获得金币奖励!
下载pdf