文件流:"fopen","fclose",“ftell”"fseek","fgets","fprintf" ,“feof”,"fwrite","fread"
char const* filename="D:/hello.txt";
路径名使用的是“/”或者使用 转义字符“\\”;
"fopen",
FILE *fp=fopen(char const *name,char const mode);
e.g:FILE *fp = fopen(filename,"wb");
打开文件流,name为要打开文件的路径,如这里的filename;mode 为对文件的操作模式,通常使用:“wb”(写操作),“rb”(读操作);
如果打开文件成功返回一个指向FILE结构的指针;否则,返回一个NULL指针;
"fclose",
fclose(FILE* name);
关闭文件流,name 为之前打开的文件指针,如这里的filename;
如果执行成功返回0,否则返回EOF;
e.g: fclose(fp);
"ftell",
long ftell(FILE *stream);
表示返回下一个读取或者写入将要开始的位置距离文件起始位置的偏移量。
e.g:
fseek(fp,5,SEEK_SET);
int i = ftell(fp); //这里i=5;
"fseek",
int fseek(FILE *stream, long offset, int from);
表示对将要写入的位置的定位;
stream为打开的文件指针,filename;
offset为距离from参数的相对距离;
from为定位的基准;模式为:SEEK_SET(从流的起始位置起,往后offset个字节)
SEEK_CUR(从流的当前位置起,往前往后offset个字节)
SEEK_END(从流的末尾起,往前往后offset个字节)
e.g:
fseek(fp,-5,SEEK_END);
fread(buf,1,4,fp);
"fgets",
char *fgets( char *buffer, int buffer_size, FILE* stream);
从指定的stream读取字符,并复制到buffer中。当读取到一个换行符号“\n”并存储到缓冲区之后就不在读取;如果缓冲区内存储的字符数达到buffer_size-1个时,同样停止读取。
下次调用fgets将从流的下一个字符开始读取。在任何一个情况下,一个NUL字节降被添加到缓冲区所存储数据的末尾,使之成为一个字符串;
如果失败,fgets返回一个NULL指针;否则返它的第一个参数(指向缓冲区的指针);
e.g:
char* ret = fgets(buf,512,fp); //成功,则返回buf指针;
"fprintf",
int fprintf(FILE *stream,char const *format,......) // 将数据转换成字符串文本,并写入stream文件中;
等于:
char buf[512];
sprintf(buf,"%s\n",fp);
fwrite(buf,1,strlen(line),fp);
e.g : fprintf(fp, "%s\n", buf);
"fwrite",
size_t fwrite(const void* buffer, size_t size, size_t count, FILE* stream);
size 恒为1;
将buffer中的 count个字节写入到文件steam中;
e.g:
fwrite(buf,1,4,fp);
"fread",
size_t fread(const void* buffer,size_t size, size_t count ,FILE *stream)
size恒为1; 从stream文件中读取count个字节存放buffer中;
返回值为:实际读取到的字节个数;
e.g:
fread(buf,1,4,fp);
"feof",
int feof(FILE *stream);
如果流当前处于文件尾,feof函数返回真。
e.g:
while (!feof(fp))
{
char* ret = fgets(buf, 512, fp);
if (ret)
{
printf("got::%s", ret);
}
}
举例:
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
using namespace std; int main()
{
const char* filename = "d:/aaa.txt";
FILE* fp = fopen(filename, "wb"); if (fp == NULL)
{
printf("failed to open file\n");
return -;
} char buf[] = {};
int m, n;
printf("请输入两个整数:");
scanf("%d%d",&m,&n); sprintf(buf,"m=%d,n=%d",m,n);
fwrite(buf,, strlen(buf), fp); //fprintf(fp,"f=%d,g=%d",m,n);
fclose(fp);
system("pause");
return ;
}
文件流:"fopen","fclose",“ftell”"fseek","fgets","fprintf" ,“feof”,"fwrite","fread"的更多相关文章
- 文件操作 fopen() fclose()
#define _CRT_SECURE_NO_DEPRECATE /*取消scanf,printf不安全之类的错误提示*/ /* fopen example */ #include <stdio ...
- PHP 文件处理----fopen(),fclose(),feof(),fgets(),fgetc()
fopen() 函数用于在 PHP 中打开文件. 打开文件 fopen() 函数用于在 PHP 中打开文件. 此函数的第一个参数含有要打开的文件的名称,第二个参数规定了使用哪种模式来打开文件: < ...
- 移动文件流的读写指针---fseek
函数原型:int fseek(FILE *stream,long offset,int origin) stream:文件指针, offset:偏移量,正数表示正向偏移,负数表示负向偏移.origin ...
- c语言中的文件流
一.打开和关闭文件 #include int main( void ) { FILE* pReadFile = fopen( "E:\\mytest.txt", "r&q ...
- FILE文件流的中fopen、fread、fseek、fclose的使用
FILE文件流用于对文件的快速操作,主要的操作函数有fopen.fseek.fread.fclose,在对文件结构比较清楚时使用这几个函数会比较快捷的得到文件中具体位置的数据,提取对我们有用的信息,满 ...
- C语言基础(20)-文件操作(fopen,getc,fclose)
一.文件操作 读文件的顺序: 1.先打开文件 2.读写文件 3.关闭文件 1.1 fopen FILE *fopen( const char *path, const char *mode ); 函数 ...
- 函数fgets和fputs、fread和fwrite、fscanf和fprintf用法小结 (转)
函数fgets和fputs.fread和fwrite.fscanf和fprintf用法小结 字符串读写函数fgets和fputs 一.读字符串函数fgets函数的功能是从指定的文件中读一个字符串到字符 ...
- Linux 文件流管理
1. 打开/关闭文件 1). 打开文件 / fopen 作用: 打开一个文件,将其与文件流联系起来,方便后续的操作 头文件: #include <stdio.h> 函数原型: FILE * ...
- (C/C++学习)2.C语言中文件流操作基本函数总结
函数所在头文件:stdio.h 说明:前半部分主要为对各个文件流操作函数的例举,后半部分着重于上机运行分析.文中部分引用自王桂林老师的C/C++课件. 1.FIELE *fopen(const cha ...
随机推荐
- node.js开发hello world
在你的 D 盘下面创建一个 server.js,写入以下内容 ---------------------------------------------------- var http = requi ...
- tcp slowstart (TCP 慢启动)
tcp slowstart (TCP 慢启动) 慢启动定义 慢启动,是传输控制协议使用的一种拥塞控制机制.慢启动也叫做指数增长期.慢启动是指每次TCP接收窗口收到确认时都会增长.增加的大小就是已确认段 ...
- Where to Run LightOJ - 1287(概率dp)
Where to Run LightOJ - 1287(概率dp) 题面长长的,看了半天也没看懂题意 不清楚的地方,如何判断一个点是否是EJ 按照我的理解 在一个EJ点处,要么原地停留五分钟接着走,要 ...
- golang effective 翻译
参考 Effective Go 官方文档 其他参考译文 https://studygolang.com/articles/3228 http://docscn.studygolang.com/doc/ ...
- BZOJ4032 [HEOI2015]最短不公共子串 【后缀自动机 + 序列自动机 + dp】
题目链接 BZOJ4032 题解 首先膜\(hb\) 空手切神题 一问\(hash\),二问枚举 三问\(trie\)树,四问\(dp\) 南二巨佬神\(hb\) 空手吊打自动机 \(orz orz ...
- GDB调试——经验总结
GDB调试的一些很有用经验: 1. gdb调试,如果有参数,可以在run命令后加,也可以使用set args :如果是使用gdbserver+gdb的远程调试方式,参数可以在gdbserver后面加. ...
- Codeforces Round #357 (Div. 2) C
C. Heap Operations time limit per test 1 second memory limit per test 256 megabytes input standard i ...
- PAT L1 049 天梯赛座位分配
天梯赛每年有大量参赛队员,要保证同一所学校的所有队员都不能相邻,分配座位就成为一件比较麻烦的事情.为此我们制定如下策略:假设某赛场有 N 所学校参赛,第 i 所学校有 M[i] 支队伍,每队 10 位 ...
- How to secure remote desktop connections using TLS/SSL
How to secure remote desktop connections using TLS/SSL based authentication Requirement When you ena ...
- [fjwc2015]Screen [从hzw神犇那里扒来的题]
[题目描述] 码农有一块超新星屏幕,它有N个像素点,每个像素点有亮度和灰度两个参数,记为I和H, 范围都是0~32000. 一天,码农突发奇想,想知道哪个点比较容易亮瞎眼睛.为此,他定义了一个瞎眼指数 ...