C C++ POSIX 的一些 IO 操作
一些 C C++ POSIX 的 IO 操作总结
- 文件-内存之间
- 内存-内存之间
- POSIX 有无缓冲的 IO 操作
对文件的操作,读文件至内存,从内存写至文件
// 读文件至内存buf中
void Fread()
{
char buf[BUFSIZE];
size_t flen = 0;
FILE *fp = fopen("./foo", "r+");
flen = fread(buf, sizeof(char), BUFSIZE, fp); // fp -> buf
printf("read len: %lu\n", flen);
printf("Fread text:\n%s\n\n", buf);
fclose(fp);
}
// 将内存 buf 中的内容写入打开的文件 fp 中
void Fwrite()
{
char buf[BUFSIZE] = BUFTEXT;
size_t flen = 0;
FILE *fp = fopen("./foo", "w+");
flen = fwrite(buf, sizeof(char), strlen(buf), fp); // buf -> fp
printf("Fwrite write len: %lu\n\n", flen);
fclose(fp);
}
// 将fp 换为 stdin 输入至 buf 中
void Fscanf()
{
char buf[BUFSIZE];
size_t flen = 0;
FILE *fp = fopen("./foo", "r+");
while(fscanf(fp, "%s", buf) != EOF) // fp -> buf, terminated by blank char
printf("Fscanf text:\n%s\n", buf);
printf("\n");
fclose(fp);
}
// C++ 文件流,输入至内存中,由于流遇到空格等空白符停止所以需循环将流中的内容全部输入至
// 内存(string)中,直至返回 EOF
void Ifstream()
{
ifstream ifs("./foo");
string buf;
while (ifs >> buf) // ifs -> buf
cout <<"Ifstream: " << buf << endl;
// char *str = new char[100];
// ifs.read(str, 10);
// whlile (getline(ifs, buf))
// cout << "Ifstream: " << buf << endl;
ifs.close();
cout << endl;
}
// fp 换为 stdout, buf 中的内容写入至 fp 中
void Fprintf()
{
char buf[BUFSIZE] = "ioi ioi";
int flen = 0;
FILE *fp = fopen("./foo", "w+");
flen = fprintf(fp, "%s", buf); // buf -> fp
printf("Fprintf len: %d\n", flen);
fclose(fp);
}
void Ofstream()
{
ofstream ofs("./foo", ios::app | ios::out);
string buf = "quick,,time go on";
// ofs << buf;
ofs.write(buf.c_str(), buf.size());
ofs.close();
}
字符流的操作,内存至内存
// 文件流 stdio 换为 str, 格式化输入
void Sscanf()
{
char str[BUFSIZE] = BUFTEXT;
char buf[BUFSIZE];
sscanf(str, "%s", buf); // str -> buf
printf("Sscanf text:\n%s\n\n", buf);
}
// istringstream 对象 iss 绑定 buf,作为输入流输入至 word(string)
void Istringstream()
{
string buf = "hello world";
string word;
istringstream iss(buf); // buf -> iss
while (iss >> word) // iss -> word, repeatedly
cout << "Istringstream: " << word << endl;
}
// 与 sscanf() 类似, 格式化输出
void Sprintf()
{
char str[BUFSIZE] = BUFTEXT;
char buf[BUFSIZE];
sprintf(buf, "%s", str); // str -> buf
printf("Sprintf text:\n%s\n\n", buf);
}
// 与 istringstream 类似
void Ostringstream()
{
string buf = BUFTEXT;
string word;
ostringstream oss;
oss << buf; // buf -> oss
word = oss.str(); // oss -> word
cout << "Ostringstream: " << word << endl;
}
Linux 有无缓冲的 IO操作 (参考 UNP)
// 无缓冲, 普通的 read() write() 并不难保证完成所需要传送的字符数
ssize_t rio_readn(int fd, void *usrbuf, size_t n)
{
size_t nleft = n;
ssize_t nread;
char *bufp = usrbuf;
while (nleft > 0) {
if ((nread = read(fd, bufp, nleft)) < 0) {
if (errno == EINTR) // interrupted by sig handler return
nread = 0; // call read() again
else
return -1; // errno set by read()
} else if (nread == 0)
break; // EOF
nleft -= nread;
bufp += nread;
}
return (n - nleft);
}
// not buff read
ssize_t rio_writen(int fd, void *usrbuf, size_t n)
{
size_t nleft = n;
ssize_t nwritten;
char *bufp = usrbuf;
while(nleft > 0) {
if ((nwritten = write(fd, bufp, nleft)) <= 0) {
if (errno == EINTR)
nwritten = n;
else
return -1;
}
nleft -= nwritten;
bufp += nwritten;
}
return n;
}
// IO 缓冲区结构体
typedef struct {
int rio_fd;
int rio_cnt;
char *rio_bufptr;
char rio_buf[RIO_BUFSIZE];
} rio_t;
// 与 read() 语义相同
// 如果缓冲区为空会通过调用 read() 填满它
static ssize_t rio_read(rio_t *rp, char *usrbuf, size_t n)
{
int cnt;
while (rp->rio_cnt <= 0) { // refill if buf is empty
rp->rio_cnt = read(rp->rio_fd, rp->rio_buf, sizeof(rp->rio_buf));
if (rp->rio_cnt < 0) {
if (errno != EINTR)
return -1;
} else if (rp->rio_cnt == 0) { // EOF
return 0;
} else {
rp->rio_bufptr = rp->rio_buf; // reset buffer ptr
}
}
// copy min(n, rp->cnt) bytes from internal buf to user buf
cnt = n;
if (rp->rio_cnt < n)
cnt = rp->rio_cnt;
memmove(usrbuf, rp->rio_bufptr, cnt);
rp->rio_bufptr += cnt;
rp->rio_cnt -= cnt;
return cnt;
}
一点小结
- 本质是操作对象的变化
// C
printf() -- stdout scanf() -- stdin
fprintf() -- FILE* fscanf() -- FILE*
sprintf() -- char* sscanf() -- str
// C++ 与上类似, 都具有缓冲区
ostream istream
ofstream ifstream
ostringstream istringstream
- 带有缓冲区的 rio_read() 有时效率很高,因为不必一直在内核-用户态之间切换
C C++ POSIX 的一些 IO 操作的更多相关文章
- python之协程与IO操作
协程 协程,又称微线程,纤程.英文名Coroutine. 协程的概念很早就提出来了,但直到最近几年才在某些语言(如Lua)中得到广泛应用. 子程序,或者称为函数,在所有语言中都是层级调用,比如A调用B ...
- Linux学习记录--文件IO操作相关系统编程
文件IO操作相关系统编程 这里主要说两套IO操作接口,各自是: POSIX标准 read|write接口.函数定义在#include<unistd.h> ISO C标准 fread|fwr ...
- Linux文件IO操作
来源:微信公众号「编程学习基地」 目录 文件操作 Linux文件类型 Linux文件权限 修改文件权限 Linux error 获取系统调用时的错误描述 打印错误信息 系统IO函数 open/clos ...
- [.NET] 利用 async & await 进行异步 IO 操作
利用 async & await 进行异步 IO 操作 [博主]反骨仔 [出处]http://www.cnblogs.com/liqingwen/p/6082673.html 序 上次,博主 ...
- 文件IO操作..修改文件的只读属性
文件的IO操作..很多同行的IO工具类都是直接写..但是如果文件有只读属性的话..则会写入失败..所以附加了一个只读的判断和修改.. 代码如下: /// <summary> /// 创建文 ...
- JAVASE02-Unit08: 文本数据IO操作 、 异常处理
Unit08: 文本数据IO操作 . 异常处理 * java.io.ObjectOutputStream * 对象输出流,作用是进行对象序列化 package day08; import java.i ...
- JAVASE02-Unit07: 基本IO操作 、 文本数据IO操作
基本IO操作 . 文本数据IO操作 java标准IO(input/output)操作 package day07; import java.io.FileOutputStream; import ja ...
- IO操作概念。同步、异步、阻塞、非阻塞
“一个IO操作其实分成了两个步骤:发起IO请求和实际的IO操作. 同步IO和异步IO的区别就在于第二个步骤是否阻塞,如果实际的IO读写阻塞请求进程,那么就是同步IO. 阻塞IO和非阻塞IO的区别在于第 ...
- Java基础复习笔记系列 七 IO操作
Java基础复习笔记系列之 IO操作 我们说的出入,都是站在程序的角度来说的.FileInputStream是读入数据.?????? 1.流是什么东西? 这章的理解的关键是:形象思维.一个管道插入了一 ...
随机推荐
- YTU 2769: 结构体--成绩统计
2769: 结构体--成绩统计 时间限制: 1 Sec 内存限制: 128 MB 提交: 1021 解决: 530 题目描述 建立一个简单的学生信息表,包括:姓名.性别.年龄及一门课程的成绩,统计 ...
- 关于OpenFileDialog的使用(转)
OpenFileDialog控件有以下基本属性 InitialDirectory 对话框的初始目录 Filter 要在对话框中显示的文件筛选器,例如,"文本文件(*.txt)|*.txt|所 ...
- 牛客小白月赛15 C 表单 ( map 使用)
链接:https://ac.nowcoder.com/acm/contest/917/C来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言52428 ...
- js将字符串中所有反斜杠\替换成正斜杠/
区分正斜杠与反斜杠: 正斜杠:http://.http紧跟着的斜杠,离手输入最近的斜杠,shift中间斜杠.45度角斜杠.正斜杠不需要转义 反斜杠:回车与空格之间.程序表示时需要转义成\\. str. ...
- Codeforces 19E 树上差分
思路: 先随便建出来一棵搜索树(图可能不连通?) 每一条非树边(剩下的边)和树边都可以构成一个环. 我们只看一个非树边和某些树边构成的这些环. 分成三种情况: 1.没有奇环 所有边都可以删 2.有一 ...
- 【POJ3255/洛谷2865】[Usaco2006 Nov]路障Roadblocks(次短路)
题目: POJ3255 洛谷2865 分析: 这道题第一眼看上去有点懵-- 不过既然要求次短路,那估计跟最短路有点关系,所以就拿着优先队列优化的Dijkstra乱搞,搞着搞着就通了. 开两个数组:\( ...
- sublime text3配置插件
之前一直习惯用记事本写代码,懒得用IDE,虽然知道用 IDE效率高一些,不过觉得还是用记事本纯手写代码,比较容易记忆.直到昨天写代码遇到了点问题,截图给师兄看,师兄就问我是不是用记事本写代码,为什么不 ...
- Miller Rabin 大素数测试
PS:本人第一次写随笔,写的不好请见谅. 接触MillerRabin算法大概是一年前,看到这个算法首先得为它的神奇之处大为赞叹,竟然可以通过几次随机数据的猜测就能判断出这数是否是素数,虽然说是有误差率 ...
- jQuery——链式编程与隐式迭代
链式编程 1.原理:return this; 2.通常情况下,只有设置操作才能把链式编程延续下去.因为获取操作的时候,会返回获取到的相应的值,无法返回 this. 3.end():结束当前链最近的一次 ...
- CSS——行业动态demo
1.padding的运用:子div继承父div的宽,子div的padding-left值是不会撑大的. 2.背景图片的运用:不平铺.定位 3.ul本身就是一个盒子,它的高度是li中的字体的默认高度撑起 ...