1.IO函数是围绕文件描述符的,而标准IO库是围绕流(stream)进行的
当用标准IO库打开或者创建一个文件的时候,已经使一个流和一个文件相关联
2.ASCII字符集:一个字用一个字节表示。国际字符集:一个字符用多个字节表示
3.流的定向(stream's orientation)决定了流的读写的字符是单字节还是多字节的
4.fwide函数可以用于设置流的定向:当一个流最初被创建的时候,它并没有定向。
#include <stdio.h>
#include <wchar.h>
int fwide(FILE *fp, int mode);
mode为负 指定的流是定向的
mode为正 指定的流是宽定向的
mode为0 不指定,但是返回标识该流定向的值
注意:1fwide并不改变已经定向后的流的定向
2 无出错返回
5.当打开一个流时,标准IO函数fopen返回一个指向FILE对象的指针,该对象是一个结构,包含了标准IO库为管理该流需要的所有信息,包括:实际IO的文件描述符,指向用于该缓冲区的指针,缓冲区长度,当前在缓冲区中年的字符数以及出错标志等。
6.标准输入STDIN_FILENO,标准输出STDOUT_FILENO,标准错误STDERR_FILENO
在头文件<stdio.h>中有指针定义
7.缓冲 目的:尽可能减少使用read和write调用次数
-1.全缓冲:填满标志IO缓冲区后才进行实际IO操作
-2.行缓冲:在输入和输出中遇到换行符的时候,标志IO库执行IO操作。
flush缓冲:标准IO缓冲区的写操作,在终端驱动程序方面指的是丢弃已存储在缓冲区中的数据
对于行缓冲有两个限制:
1.IO库收集每一行的缓冲区长度是固定的,所以只要填满了缓冲区,即便没有写换行符,也进行IO操作。
2.//TODO还没理解 后续更新
8.修改流的缓冲类型
#include<stdio.h>
void setbuf(FILE *restrict fp, char *restrict buf);
int setvbuf(FILE *restrict fp, char *restrict buf,int mode,size_t size);
解释:
一定要在流已被打开后调用,且应该在该流执行任何一个其他操作之前调用
setbuf函数 buf如果是NULL则为关闭缓冲,否则为全缓冲(如果该流与一个终端设备相关,某些情况下也可以设置成行缓冲)
setvbuf函数里mode参数
_IOFBF 全缓冲
_IOLBF 行缓冲
_IONBF 不带缓冲
如果不带缓冲:忽略buf和size
如果带缓冲但是buf是NULL:自动为期分配适当长度的缓冲区。指的是常量BUFSIZ的值
9.打开流
#include <iostream>
FILE *fopen(const char *restrict pathname,const char *restrict type)
FILE *freopen(const char *restrict pathname,const char *restrict type,FILE *restrict fp);
FILE *fdopen(int fd, const char *type)
//三个函数返回值:成功:返回文件指针 出错:返回NULL
三个函数的区别
1.fopen打开一个路径名为pathname的一个指定文件
2.freopen函数在一个指定的流上打开一个指定的文件,如果流已经打开,先关闭该流。若该流已经定向,使用freopen清除定向。通常用于将一个指定的文件打开为一个预定的流:标准输入 标准输出 或者标准错误
3.fdopen函数获取一个已有的文件描述符(从open,dup,dup2,pipe,socket,accpet),并使一个标准的IO流与该描述符相结合。此函数通常用于创建管道和网络通信通道函数返回的描述符。因为这些特殊类型的文件不能用标准IO函数fopen打开
type参数
b的作用是用于标准IO系统区分文本文件和二进制文件
但是UNIX内核并不对b进行区分,所以在UNIX系统的环境下,b是没啥用的