C-fopen,fwrite,fread,fseek,fgets,popen,access笔记
FILE * fopen(const char * path,const char * mode);
- 所需库: <stdio.h>
返回值
- FILE是C语言定义的标准数据结构,如果open()失败,则返回NULL
path
- 路径
mode
- 打开模式,包括有以下几种
- r 以只读方式打开文件,该文件必须存在。
- r+ 以读/写方式打开文件,该文件必须存在。
- rb+ 以读/写方式打开一个二进制文件,只允许读/写数据。
- rt+ 以读/写方式打开一个文本文件,允许读和写。
- w 打开只写文件,若文件存在则长度清为 0,即该文件内容消失,若不存在则创建该文件。
- w+ 打开可读/写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
- a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留(EOF 符保留)。
- a+ 以附加方式打开可读/写的文件。若文件不存在,则会建立该文件,如果文件存在,则写入的数据会被加到文件尾后,即文件原先的内容会被保留(原来的 EOF 符不保留)。
- wb 以只写方式打开或新建一个二进制文件,只允许写数据。
- wb+ 以读/写方式打开或建立一个二进制文件,允许读和写。
- wt+ 以读/写方式打开或建立一个文本文件,允许读写。
- at+ 以读/写方式打开一个文本文件,允许读或在文本末追加数据。
- ab+ 以读/写方式打开一个二进制文件,允许读或在文件末追加数据。
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
size_t fwrite(const void *ptr, size_t size, size_t nmemb,FILE *stream);
返回值
- fread()和fwrite()返回的是成功读取/写入的条目数(也就是nmemb大小),如果到达文件末尾或读写错误,则返回0
ptr
- 指针pointer,用来读出或写入的数据区
size
- 单个数据项的大小,单位为字节
nmemb
- 读写的条目数(实际等于读写字节大小 )
PS:尽量将size大小写为最小值(1字节)
int fclose(FILE *stream);
- 关闭流 stream,刷新缓冲区,更新文件
示例1:
- #include<string.h>
- #include<stdio.h>
- int main(void)
- {
- FILE *fp = NULL;
- const char *buf = "";
- fp = fopen("DUMMY.FIL","w");/*创建一个包含10个字节的文件*/
- fwrite(buf,strlen(buf),,fp);/*将buf内容写入到文件中*/
- fclose(fp);/*关闭文件*/return ;
- }
int fseek(FILE *stream, long offset, int fromwhere);
返回值
- 成功,返回0,失败返回-1,并设置error的值
offset
- 偏移量,正数表示正向偏移,负数表示负向偏移,单位为字节
Fromwhere
- 偏移起始位置,有3种位置:
- SEEK_SET(0): 文件开头
- SEEK_CUR(1): 当前位置
- SEEK_END(2): 文件结尾
示例2-读写十六进制:
- #include <stdio.h>
- #include <stdlib.h>
- #include <string.h>
- int main(int argc,char* argv[])
- {
- FILE *fp = NULL;
- int readbuf;
- int readEnd;
- int writebuf=;
- int len;
- fp = fopen("./1.txt","rb+");
- printf("read 1.txt: fp==NULL=%d size=%d\n",fp == NULL,sizeof(readbuf));
- if(fp!=NULL) //打开成功,读数据
- {
- len=fread(&readbuf,sizeof(int),,fp); //读写开头的第一个int型数据
- printf("read len=%d data=%d\n",len,readbuf);
- fseek(fp,-sizeof(int),SEEK_END); //将fp指向文件末尾的最后一个int型数据处
- fread(&readEnd,sizeof(int),,fp);
- printf("read file end =%d\n",readEnd);
- fclose(fp);
- }
- else //打开失败,则创建文件
- {
- fp = fopen("./1.txt","wb+");
- printf("write 1.txt: fp==NULL=%d size=%d\n",fp == NULL,sizeof(readbuf));
- if(fp!=NULL)
- {
- len=fwrite(&writebuf,sizeof(int),,fp); //写入一个int型数据
- printf("write len=%d \n",len);
- fclose(fp);
- }
- }
- return ;
- }
运行第一次:
运行第二次
示例3-读写某个文件的十六进制以及对应字符串
代码如下:
- #include <stdio.h>
- #include <stdlib.h>
- #include <string.h>
- int main(int argc,char* argv[])
- {
- FILE *fp = NULL;
- unsigned char buf[];
- int seek;
- int len=;
- int readl=;
- char s[]="./";
- strcat(s,argv[]);
- printf("file:%s\n",s); //打印要访问当前目录下的哪个文件
- seek=strtoul(argv[],,);
- len=strtoul(argv[],,);
- fp = fopen(s,"rb+");
- if(fp!=NULL) //打开成功,读数据
- {
- printf("input seek=%d len=%d \n",seek,len); //打印,从文件哪个字节位置处,读多少个字节
- fseek(fp,seek,);
- readl=fread(&buf,,len,fp);
- printf("read len=%d\n",readl); //打印实际读出的字节长度
- for(int i=;i<=(readl/);i++)
- {
- for(int j=;j<;j++)
- {
- if((i*+j)>=readl)
- printf(" ");
- else
- printf("%d ",buf[i*+j]); //打印读出的16进制数据
- }
- printf(" ||");
- for(int j=;j<;j++)
- {
- if((i*+j)>=readl)
- break;
- printf("%c",buf[i*+j]); //打印16进制数据对应的字符串
- }
- printf("\n");
- }
- fclose(fp);
- }
- return ;
- }
以访问test.txt文件为例,它的内容如下:
运行示例:
char *fgets(char *buf, int bufsize, FILE *stream);
读取的数据保存在buf指向的字符数组中,每次最多读取bufsize-1个字符(第bufsize个字符赋'\0'),如果文件中的该行,不足bufsize-1个字符,则读完该行就结束。
如若该行(包括最后一个换行符)的字符数超过bufsize-1,则fgets只返回一个不完整的行
返回值
- 如果为NULL,表示读到文件结尾或者出错,否则返回读成功的缓存区地址
bufsize
- 如果n=1,会返回空串
示例-打印文件全部数据:
- #include <stdio.h>
- #include <stdlib.h>
- #include <string.h>
- int main(int argc,char* argv[])
- {
- FILE *fp = NULL;
- char readbuf[];
- fp = fopen("./1.txt","r+");
- printf("(DEBUG)read 1.txt: fp==NULL=%d\n",fp == NULL);
- if(fp!=NULL) //打开成功,读数据
- {
- while(fgets(readbuf, sizeof(readbuf),fp))
- {
- printf("%s",readbuf);
- }
- fclose(fp);
- }
- return ;
- }
FILE *popen(const char *command, const char *type);
int pclose(FILE *stream);
头文件#include <stdio.h>
- 若popen ()的type是”r”,则文件指针是连接到子进程执行command命令的标准输出。
- 若popen ()的type是”w”,则文件指针连接到子进程执行command命令的标准输入。
示例
- #include <stdio.h>
- #include <stdlib.h>
- #include <string.h>
- int run_command(const char *cmd, const char *type)
- {
- FILE *fp;
- int res; char buf[];
- if ((fp = popen(cmd, type)) ==NULL)
- {
- printf("popen err \n");
- return -;
- }
- if(type[]=='r') //如果是读数据
- {
- while(fgets(buf, sizeof(buf),fp))
- {
- printf("%s",buf);
- }
- }
- pclose(fp);
- return ;
- }
- int main(int argc,char* argv[])
- {
- run_command("vi 1.txt","r");
- return ;
- }
效果:
int access(const char *pathname, int mode);
头文件:#include <unistd.h>
用来检测访问的文件属性,是否可以读写,存在,执行
mode
模式有以下几种:
- #define F_OK 0 /* Check for file existence */
- #define X_OK 1 /* Check for execute permission. */
- #define W_OK 2 /* Check for write permission */
- #define R_OK 4 /* Check for read permission */
示例-检测文件是否存在
- #include <stdio.h>
- #include <unistd.h>
- int file_exists(char *filename);
- int main(void)
- {
- printf("Does NOTEXIST.FIL exist: %s\n",
- file_exists("./1.txt") ? "YES" : "NO");
- return ;
- }
- int file_exists(char *filename)
- {
- return (access(filename, ) == );
- }
如果在嵌入式linux中,则有可能在写数据后强制关电,此时数据还在缓冲区,并没写到flash中,所以需要在fclose()前面加上:
- fflush(fp); //会把缓冲区中的文件写到文件系统中
- fsync(fileno(fp)); //同步数据到flash
- fclose(fp);
C-fopen,fwrite,fread,fseek,fgets,popen,access笔记的更多相关文章
- fopen,fwrite,fread使用
fopen, fwrite, fread详解 1.头文件 #include <stdio.h> 2.fopen (1) 函数原型 FILE *fopen(char *filename, * ...
- 文件流:"fopen","fclose",“ftell”"fseek","fgets","fprintf" ,“feof”,"fwrite","fread"
char const* filename="D:/hello.txt"; 路径名使用的是“/”或者使用 转义字符“\\”: "fopen", FILE *fp= ...
- PHP 文件读取 fread、fgets、fgetc、file_get_contents 与 file 函数
fread().fgets().fgetc().file_get_contents() 与 file() 函数用于从文件中读取内容. fread() fread() 函数用于读取文件(可安全用于二进制 ...
- PHP读取文件函数fread,fgets,fgetc,file_get_contents和file函数的使用总结
fread().fgets().fgetc().file_get_contents() 与 file() 函数用于从文件中读取内容. 1.fread() fread()函数用于读取文件(可安全用于二进 ...
- (转载)C++文件读写函数之——fopen、fread和fwrite、fgetc和fputc、fgets和fputs、ftellf和fseek、rewind
http://blog.sina.com.cn/s/blog_61437b3b0102v0bt.html http://blog.csdn.net/chenwk891/article/details/ ...
- C++文件读写函数之——fopen、fread和fwrite、fgetc和fputc、fgets和fputs、ftellf和fseek、rewind
由于最近经常使用到c语言中的读写文件,所以在此总结以下,方便以后查找. 在c中,文件操作都是由库函数来实现的,主要是分为读和写两种操作,以下详细讲解以下所有有关文件操作的邯郸乎的用法: //C++写入 ...
- FILE文件流的中fopen、fread、fseek、fclose的使用
FILE文件流用于对文件的快速操作,主要的操作函数有fopen.fseek.fread.fclose,在对文件结构比较清楚时使用这几个函数会比较快捷的得到文件中具体位置的数据,提取对我们有用的信息,满 ...
- PHP读写大“二进制”文件,不必申请很大内存(fopen、fread、fwrite、fclose)
<?php /** * 读写大二进制文件,不必申请很大内存 * 只有读取到内容才创建文件 * 保证目录可写 * * @param string $srcPath 源文件路径 * @param s ...
- 文件处理函数fopen、fread、fseek、fclose的使用实例介绍
FILE文件流用于对文件的快速操作,主要的操作函数有fopen.fseek.fread.fclose,在对文件结构比较清楚时使用这几个函数会比较快捷的得到文件中具体位置的数据,提取对我们有用的信息,满 ...
随机推荐
- 产生 unmerge path git
1. Pull is not possible because you have unmerged files. 症状:pull的时候 $ git pull Pull is not possible ...
- hbuilder下用plus.barcode.Barcode做二维码扫描,当二维码容器的高度设置过低时,启动扫描会发生闪退
解决办法: 将固定高度改为百分比
- 学习Java的进度
这周我们通过老师的讲解带着我们回到了第八周的知识点.lambda表达式也是一种简化程序的好方法,通过回调程序的测试可以对比出lambda 表达式少的不是一两行代码,可以少了类中方法的定义,直接使用.内 ...
- Email发展历史
据我所知:1987年9月20日,有“中国互联网第一人”之称的钱天白从北京经意大利向前联邦德国卡尔斯鲁厄大学发出了中国第一封电子邮件,内容是“ 穿越长城,走向世界”.这是中国人在网络上的第一步,他开创了 ...
- struts2 简单注解配置代替xml配置文件
1. 主要文件 LoginAction.javapackage com.edu.struts2.action;import org.apache.struts2.convention.annotati ...
- 【设计经验】4、SERDES关键技术总结
一.SERDES介绍 随着大数据的兴起以及信息技术的快速发展,数据传输对总线带宽的要求越来越高,并行传输技术的发展受到了时序同步困难.信号偏移严重,抗干扰能力弱以及设计复杂度高等一系列问题的阻碍.与并 ...
- nodejs常用代码片段
自动创建目录(多级) 相比起使用递归创建,调用 sheljsl 模块简单得多 const shell = require('shelljs') const fs = require('fs') if ...
- 【CF429E】 Points and Segments(欧拉回路)
传送门 CodeForces 洛谷 Solution 考虑欧拉回路有一个性质. 如果把点抽出来搞成一条直线,路径看成区间覆盖,那么一个点从左往右被覆盖的次数等于从右往左被覆盖的次数. 发现这个性质和本 ...
- 如何把web.xml中的context-param、Servlet、Listener和Filter定义添加到SpringBoot中
把传统的web项目迁移到SpringBoot中,少不了web.xml中的context-param.Servlet.Filter和Listener等定义的迁移. 对于Servlet.Filter和Li ...
- 封装手风琴!使用jQuery!
//封装手风琴 /** * * * */ $.fn.accordion = function (colors, width) { var width=width||0; var colors= col ...