博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
阅读优秀源码时可能会用的C函数(记录)
阅读量:5908 次
发布时间:2019-06-19

本文共 3656 字,大约阅读时间需要 12 分钟。

打开文件

使用 fopen( ) 函数来创建一个新的文件或者打开一个已有的文件,这个调用会初始化类型 FILE 的一个对象,类型 FILE 包含了所有用来控制流的必要的信息。下面是这个函数调用的原型

FILE *fopen( const char * filename, const char * mode );复制代码

filename 是字符串,用来命名文件, mode 的值可以是下列值中的一个:

如果处理的是二进制文件,则需使用下面的访问模式来取代上面的访问模式:

"rb", "wb", "ab", "rb+", "r+b", "wb+", "w+b", "ab+", "a+b"复制代码

关闭文件

为了关闭文件,请使用 fclose( ) 函数。函数的原型如下:

int fputc( int c, FILE *fp );复制代码

如果成功关闭文件,fclose( ) 函数返回零,如果关闭文件时发生错误,函数返回 EOF。这个函数实际上,会清空缓冲区中的数据,关闭文件,并释放用于该文件的所有内存。EOF 是一个定义在头文件 stdio.h 中的常量。 C 标准库提供了各种函数来按字符或者以固定长度字符串的形式读写文件。

写入文件

int fputc( int c, FILE *fp );复制代码

函数 fputc() 把参数 c 的字符值写入到 fp 所指向的输出流中。如果写入成功,它会返回写入的字符,如果发生错误,则会返回 EOF。您可以使用下面的函数来把一个以 null 结尾的字符串写入到流中:

int fputs( const char *s, FILE *fp );复制代码

函数 fputs() 把字符串 s 写入到 fp 所指向的输出流中。如果写入成功,它会返回一个非负值,如果发生错误,则会返回 EOF。您也可以使用 int fprintf(FILE *fp,const char *format, ...) 函数来写把一个字符串写入到文件中

注意:请确保您有可用的 /tmp 目录,如果不存在该目录,则需要在您的计算机上先创建该目录。

#include 
int main(){ FILE *fp = NULL; fp = fopen("/tmp/test.txt", "w+"); fprintf(fp, "This is testing for fprintf...\n"); fputs("This is testing for fputs...\n", fp); fclose(fp);}复制代码

当上面的代码被编译和执行时,它会在 /tmp 目录中创建一个新的文件 test.txt,并使用两个不同的函数写入两行

读取文件

int fgetc( FILE * fp );复制代码

fgetc() 函数从 fp 所指向的输入文件中读取一个字符。返回值是读取的字符,如果发生错误则返回 EOF。下面的函数允许您从流中读取一个字符串:

char *fgets( char *buf, int n, FILE *fp );复制代码

函数 fgets() 从 fp 所指向的输入流中读取 n - 1 个字符。它会把读取的字符串复制到缓冲区 buf,并在最后追加一个 null 字符来终止字符串。 如果这个函数在读取最后一个字符之前就遇到一个换行符 '\n' 或文件的末尾 EOF,则只会返回读取到的字符,包括换行符。您也可以使用 int fscanf(FILE *fp, const char *format, ...) 函数来从文件中读取字符串,但是在遇到第一个空格字符时,它会停止读取。

#include 
int main(){ FILE *fp = NULL; char buff[255]; fp = fopen("/tmp/test.txt", "r"); fscanf(fp, "%s", buff); printf("1 : %s\n", buff ); fgets(buff, 255, (FILE*)fp); printf("2: %s\n", buff ); fgets(buff, 255, (FILE*)fp); printf("3: %s\n", buff ); fclose(fp); }复制代码

当上面的代码被编译和执行时,它会读取上一部分创建的文件,产生下列结果:

1 : This2: is testing for fprintf...3: This is testing for fputs...复制代码

首先,fscanf() 方法只读取了 This,因为它在后边遇到了一个空格。其次,调用 fgets() 读取剩余的部分,直到行尾。最后,调用 fgets() 完整地读取第二行。

二进制 I/O 函数 下面两个函数用于二进制输入和输出:

ize_t fread(void *ptr, size_t size_of_elements, size_t number_of_elements, FILE *a_file);  size_t fwrite(const void *ptr, size_t size_of_elements, size_t number_of_elements, FILE *a_file);复制代码

这两个函数都是用于存储块的读写 - 通常是数组或结构体。

fseek 可以移动文件指针到指定位置读,或插入写:

int fseek(FILE *stream, long offset, int whence);复制代码

fseek 设置当前读写点到 offset 处, whence 可以是 SEEK_SET,SEEK_CUR,SEEK_END 这些值决定是从文件头、当前点和文件尾计算偏移量 offset。 你可以定义一个文件指针 FILE *fp,当你打开一个文件时,文件指针指向开头,你要指到多少个字节,只要控制偏移量就好,例如, 相对当前位置往后移动一个字节:fseek(fp,1,SEEK_CUR); 中间的值就是偏移量。 如果你要往前移动一个字节,直接改为负值就可以:fseek(fp,-1,SEEK_CUR)。 执行以下实例前,确保当前目录下 test.txt 文件已创建:

#include 
int main(){ FILE *fp = NULL; fp = fopen("test.txt", "r+"); // 确保 test.txt 文件已创建 fprintf(fp, "This is testing for fprintf...\n"); fseek(fp, 10, SEEK_SET); if (fputc(65,fp) == EOF) { printf("fputc fail"); } fclose(fp);}复制代码

执行结束后,打开 test.txt 文件:

This is teAting for fprintf...复制代码

注意: 只有用 r+ 模式打开文件才能插入内容,w 或 w+ 模式都会清空掉原来文件的内容再来写,a 或 a+ 模式即总会在文件最尾添加内容,哪怕用 fseek() 移动了文件指针位置。

字符串常用的函数

#include 
#include
int main (){ char str1[12] = "Hello"; char str2[12] = "World"; char str3[12]; int len ; /* 复制 str1 到 str3 */ strcpy(str3, str1); printf("strcpy( str3, str1) : %s\n", str3 ); /* 连接 str1 和 str2 */ strcat( str1, str2); printf("strcat( str1, str2): %s\n", str1 ); /* 连接后,str1 的总长度 */ len = strlen(str1); printf("strlen(str1) : %d\n", len ); return 0;}复制代码

运行结果

strcpy( str3, str1) :  Hellostrcat( str1, str2):   HelloWorldstrlen(str1) :  10复制代码

c 标准库 <ctype.h>

c 标准库 <math.h>

转载地址:http://bmvpx.baihongyu.com/

你可能感兴趣的文章
汉诺塔--递归和非递归实现
查看>>
2019春总结作业
查看>>
Cherokee 1.0.13 发布
查看>>
axis调用webservice的简单方法
查看>>
could not initialize proxy - no Session
查看>>
计算机数制和运算的一点总结.
查看>>
web容器启动,获取spring bean
查看>>
第二冲刺阶段第十一天
查看>>
机器语言的介绍
查看>>
UML系列 (五) 为什么要用UML建模之建模的重要性
查看>>
http协议和https协议
查看>>
811. Subdomain Visit Count
查看>>
log4j使用总结
查看>>
JS对JSON的操作总结 (转)
查看>>
强制转换原始字符串python (转)
查看>>
[数据结构和算法]快速排序笔记
查看>>
C#由变量捕获引起对闭包的思考
查看>>
SQL Server 把当前日期中月份和几号中的0 去掉
查看>>
Asp.net中的页面跳转及post数据
查看>>
啊哈磊--算法3:快速排序
查看>>