标准IO函数以及基本知识点总结
什么是标准IO呢?有哪些特点?
标准IO是标准c库提供的对文件操作的函数接口。他的特点是:1 带缓存,2 大部分都调用系统接口函数实现。(c库就是一种实现好的函数接口,作用是屏蔽下层细节。提供上层接口。提高移植性)
我们都知道标准IO是带有缓存的,那么缓存分为几种呢?
1>全缓存:
有4096byte,截止条件有三,一是缓存满的时候,二是调用fflush的时候,三是进程正常结束的时候
2>行缓存:
有1024byte,它与全缓存截止的条件最大的差异就是另外遇到'\n'的时候。
3>不缓存:
0byte。每次都是直接调用系统接口。
那么说道标准IO就一定要提到 流 了,什么是流?
流 就是将要操作文件的地址,对一个文件操作,首先肯定要打开一个文件,所以流就是在调用fopen函数时所返回的分配内存的首地址。当然也就是将操作文件的地址。
标准IO的几个经常使用函数:
1》fopen()
函数原型 FILE *fopen(const char *path,const char *mode);
当中,path是我们要打开的流,而mode就是我们打开文件的方式了,也就决定你所打开的文件将被如何的去对待啦,有例如以下几种方式:
"r":仅仅读方式打开,打开的文件必须存在。
"r+" :读写方式打开,文件必须存在。
"w" : 仅仅写方式打开,文件不存在则创建。文件存在则清空。
"w+" : 读写方式打开,文件不存在则创建,文件存在则清空。
"a" : 仅仅写方式打开,追加的方式写到文件的尾部。文件不存在则创建。
"a+": 读写方式打开,文件不存在创建,从头開始读,从尾開始写。
以上就是经常使用的fopen的打开方式,这个必须尽量的熟记于心,才干挥斥方遒。游刃有余(诗性大发了)。。。
2》单个字符的读写函数fgetc() fputc()
int fgetc(FILE *stream)
函数功能:从指定的流中读取一个字符。 成功返回读取的字符,读到文件结尾或者失败则返回EOF(-1)
这里面须要注意的就是,返回的数值是整形的。想想为什么呢? 呵呵 。。想不通的留言给我哈O(∩_∩)O哈。
int fputc(int c,FILE* stream)
函数功能: 向指定的流中写入一个字符。成功返回写入的字符,失败返回EOF.
3>多个字符的读写函数fgets() fputs()
char * fgets(char *s,int size,FILE *stream)
函数功能:从流中最多读取size-1个字符到s保存的地址,成功返回读入字符串的地址。失败或读到文件的尾部则返回NULL,为什么最多读取 size -1 个字符呢? 首先fgets函数遇到换行符的时候就会自己主动停止,所以我们也能够利用这一点,来统计文件的行数。另外每次读取结束的时候,会自己主动的在字符的后面加上一个'\0',这就是问题的答案。你造吗?
int fputs( const char *s,FILE*stream)
函数功能: 将一个字符串写入文件,s为字符串的首地址,stream为将要写进去的文件。成功则返回写入字符的个数,失败返回-1 , 他的特点是 将字符串写入文件的时候,遇到‘\0' ,字符则结束。
4》fread() fwrite()
size_t fread(void *ptr,size_t size,size_t nmemb,FILE*stream)
功能:从一个指定的流中读取nmemb个对象,每一个对象的大小事size个字节。成功返回读取实际对象的个数(nmemb) 。 失败返回0.
size_t fwrite(const void *ptr ,size_t size,size_t nmemb , FILE*stream)
功能:向一个指定的流中写nmemb个对象。
另外,当我们在读或者写文件的时候。内核中的文件表项中会存在有offset值,它的值记录的是对文件对应操作的位置。位置非常重要的。比方你对一个文件 读或写之后。然后对文件開始写或读,你假设在这个中间没有更新你的offset值。或导致你的操作得不到你终于想要到那个结果。所以offset的值至关重要。在程序中我们能够使用fseek这个函数来实施对offset值得改动设定,
int fseek ( FILE*stream,long offset,int whence)
功能:实现文件定位,更改内核中文件表项offset的值,成功返回0。失败返回-1.
long offset 来设定偏移量,正数代表向后偏移。负号则向前偏移,whence有三个值:SEEK_SET表示从头開始,SEEK_CUR表示从当前的位置。SEEK_END表示从尾部開始。
另外再加入一个:
文件描写叙述符:
文件描写叙述符是由无符号整数表示的。进程用它来标示打开的文件,内核利用文件描写叙述符来訪问文件,打开现存文件或新建文件时,内核会返回一个文件描写叙述符,读写文件也须要使用文件描写叙述符来指定待写的文件。
通常。标准输入的文件描写叙述符是 0 。标准输出的文件描写叙述符是1 ,标准出错的文件描写叙述符是2,接下来假设再打开文件的时候。文件描写叙述符的分配原则就是未使用的最小的数字。
依据传说:
基于文件描写叙述符的操作是linux中最经常使用的操作之中的一个
标准IO函数以及基本知识点总结的更多相关文章
- 第3章 文件I/O(8)_贯穿案例:构建标准IO函数库
9. 贯穿案例:构建标准IO函数库 //mstdio.h #ifndef __MSTDIO_H__ #define __MSTDIO_H__ #include <unistd.h> #de ...
- UNIX高级环境编程(7)标准IO函数库 - 二进制文件IO,流定位,创建临时文件和内存流
1 二进制IO(Binary IO) 在前一篇我们了解了逐字符读写和逐行读写函数. 如果我们在读写二进制文件,希望以此读写整个文件内容,这两个函数虽然可以实现,但是明显会很麻烦且多次循环明显效率很低. ...
- UNIX高级环境编程(6)标准IO函数库 - 流的概念和操作
标准IO函数库隐藏了buffer大小和分配的细节,使得我们可以不用关心预分配的内存大小是否正确的问题. 虽然这使得这个函数库很容易用,但是如果我们对函数的原理不熟悉的话,也容易遇到很多问题. 1 ...
- [APUE]标准IO库(上)
一.流和FILE对象 系统IO都是针对文件描述符,当打开一个文件时,即返回一个文件描述符,然后用该文件描述符来进行下面的操作,而对于标准IO库,它们的操作则是围绕流(stream)进行的. 当打开一个 ...
- linux标准IO缓冲(apue)
为什么需要标准IO缓冲? LINUX用缓冲的地方遍地可见,不管是硬件.内核还是应用程序,内核里有页高速缓冲,内存高速缓冲,硬件更不用说的L1,L2 cache,应用程序更是多的数不清,基本写的好的软件 ...
- linux标准io的copy
---恢复内容开始--- 1.linux标准io的copy #include<stdio.h> int main(int argc,char **argv) { if(argc<3) ...
- (九)errno和perror、标准IO
3.1.6.文件读写的一些细节3.1.6.1.errno和perror(1)errno就是error number,意思就是错误号码.linux系统中对各种常见错误做了个编号,当函数执行错误时,函数会 ...
- C5 标准IO库:APUE 笔记
C5 :标准IO库 在第三章中,所有IO函数都是围绕文件描述符展开,文件描述符用于后续IO操作.由于文件描述符相关的操作是不带缓冲的IO,需要操作者本人指定缓冲区分配.IO长度等,对设备环境要求一定的 ...
- 为什么需要标准IO缓冲?
(转)标准I/O缓冲:全缓冲.行缓冲.无缓冲 标准I/O库提供缓冲的目的是尽可能地减少使用read和write调用的次数.它也对每个I/O流自动地进行缓冲管理,从而避免了应用程序需要考虑这一点所带来的 ...
随机推荐
- Python内置方法详解
1. 字符串内置方法详解 为何要有字符串?相对于元组.列表等,对于唯一类型的定义,字符串具有最简单的形式. 字符串往往以变量接收,变量名. 可以查看所有的字符串的内置方法,如: 1> count ...
- activiti工作流使用一般步骤
activiti工作流使用的一般步骤 一.在eclipse或Myeclipse中安装activiti插件: 二.通过activiti连接数据库,有以下两种连接数据库的形式: 1.通过java代码链接数 ...
- python爬虫基础04-网页解析库xpath
更简单高效的HTML数据提取-Xpath 本文地址:https://www.jianshu.com/p/90e4b83575e2 XPath 是一门在 XML 文档中查找信息的语言.XPath 用于在 ...
- (原)pat1007素数猜想
---恢复内容开始--- 1007. 素数对猜想 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 让我们 ...
- Myeclipse 添加Android开发工具
1.JDK是必须的,同时配置相应环境变量. 2.Android SDK 下载后解压缩需要把SDK目录下的tools和platform-tools加入环境变量. 3.MyEclipse中安装ADT插件 ...
- 【LeetCode】Same Tree(相同的树)
这道题是LeetCode里的第100道题. 这是题目: 给定两个二叉树,编写一个函数来检验它们是否相同. 如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的. 示例 1: 输入: 1 1 ...
- SPOJ DIVSUM - Divisor Summation
DIVSUM - Divisor Summation #number-theory Given a natural number n (1 <= n <= 500000), please ...
- 多线程下,多次操作数据库报错,There is already an open DataReader associated with this Command which must be closed first.
原文:https://www.cnblogs.com/sdusrz/p/4433108.html 执行SqlDataReader.Read之后,如果还想用另一个SqlCommand执行Insert或者 ...
- jQuery获得页面元素的绝对/相对位置
获取页面某一元素的绝对X,Y坐标,可以用offset()方法: var X = $('#DivID').offset().top; var Y = $('#DivID').offset().left; ...
- 【Luogu】P2617Dynamic Ranking(树状数组套主席树)
题目链接 树状数组套主席树有点难懂qwq 不好理解 树状数组套主席树的直观理解应该是:树状数组的每一个节点是一棵主席树. 普通区间修改我们是创建1个线段树,树状数组套主席树的时候我们就创建log个线段 ...