前言

  本文介绍使用无缓冲IO函数进行文件读写。

  所谓的无缓冲是指该IO函数通过调用系统调用实现,其实系统调用内部的读写实现也是使用了缓冲技术的。

读写步骤

  1. 打开文件  open 函数

  2. 读写文件  read write 函数

  3. ( 如果需要 )修改文件指针  lseek 函数  ( 可能和 2 交替进行 )

  4. 关闭文件  close 函数

代码示例

 //
// 本程序往一个文件中写入一个整型数组
// 然后读取这个数组并输出
// #include <unistd.h>
#include <fcntl.h>
#include <errno.h>
#include <iostream>
#include <string> using namespace std; const int LEN=; int main(void) {
string filename;
cout << "请输入要处理的文件名: ";
cin >> filename; // 打开 filename 文件。
// 注意:
// 1. 第一个参数必须转换成C的字符串格式
// 2. 如果找不到文件,就会以 777 权限创建一个新的文件。
// 3. 如果要进行读写,还要使用O_RDWR参数。
int fd = ;
if (!(fd = open(filename.c_str(), O_CREAT|O_EXCL|O_RDWR, ))) {
cout << "打开/创建文件失败" << endl;
return ;
} // 初始化测试数组
int buf[LEN];
for (int i=; i<LEN; i++) {
buf[i] = i;
} // 将数组中的数据写入到打开的文件中
if (write(fd, buf, LEN*sizeof(int)) != LEN*sizeof(int)) {
cout << "写入失败" << endl;
return ;
} // 写入指针回退两个位置
lseek(fd, -*sizeof(int), SEEK_CUR); // 继续写入数据
if (write(fd, buf, LEN*sizeof(int)) != LEN*sizeof(int)) {
cout << "写入失败" << endl;
return ;
} // 写入指针回到文件顶部
lseek(fd, , SEEK_SET); // 从文件中读取数据并输出到标准输出
int n=;
while ((n = read(fd, buf, LEN*sizeof(int))) > ) {
// 这里切记不能够直接用write输出到标准输入,因为write不知道数组里面放的数据是什么类型。
for (int i=; i<n/sizeof(int); i++) {
cout << buf[i] << " ";
}
cout << endl;
}
if (n<) {
cout << "读入失败" << endl;
return ;
} // 关闭文件
close(fd); return ;
}

小结

  1. read 和 write 函数是以二进制的方式读/写,函数本身是不会去识别数据格式的。

  2. 当程序语句比较长的时候,要注意算符的优先级。( 参考代码 58 行 )

  3. 使用完文件之后记得关闭文件描述符。

使用无缓冲IO函数读写文件的更多相关文章

  1. 第五篇:使用无缓冲IO函数读写文件

    前言 本文介绍使用无缓冲IO函数进行文件读写. 所谓的无缓冲是指该IO函数通过调用系统调用实现,其实系统调用内部的读写实现也是使用了缓冲技术的. 读写步骤 1. 打开文件 open 函数 2. 读写文 ...

  2. java IO流之三 使用缓冲流来读写文件

    原文:http://blog.csdn.net/haluoluo211/article/details/52183219 一.通过BufferedReader和BufferedWriter来读写文件 ...

  3. Python IO编程-读写文件

    1.1给出规格化得地址字符串,这些字符串是经过转义的能直接在代码里使用的字符串 需要导入os模块 import os >>>os.path.join('user','bin','sp ...

  4. Commons IO方便读写文件的工具类

    Commons IO是apache的一个开源的工具包,封装了IO操作的相关类,使用Commons IO可以很方便的读写文件,url源代码等. 普通地读取一个网页的源代码的代码可能如下 InputStr ...

  5. Python开发【第三篇】:函数&读写文件

    三元运算 三元运算,是条件语句的简单的写法.如果条件为真,则返回值1,否则,返回值2. ret = 值1 if 条件 else 值2 深浅拷贝 对于数字(int)和字符串(str)而言,赋值.深拷贝. ...

  6. Java IO如何读写文件

    Java把这些不同来源和目标的数据都统一抽象为数据流:Java语言的输入输出功能是十分强大而灵活的:在Java类库中,IO部分的内容是很庞大的,因为它涉及的领域很广泛:标准输入输出,文件的操作,网络上 ...

  7. IO流 读写文件

    读写文件 如前所述,一个流被定义为一个数据序列.输入流用于从源读取数据,输出流用于向目标写数据. 下图是一个描述输入流和输出流的类层次图. 下面将要讨论的两个重要的流是 FileInputStream ...

  8. 161228、Java IO流读写文件的几个注意点

    平时写IO相关代码机会挺少的,但却都知道使用BufferedXXXX来读写效率高,没想到里面还有这么多陷阱,这两天突然被其中一个陷阱折腾一下:读一个文件,然后写到另外一个文件,前后两个文件居然不一样? ...

  9. 161108、Java IO流读写文件的几个注意点

    平时写IO相关代码机会挺少的,但却都知道使用BufferedXXXX来读写效率高,没想到里面还有这么多陷阱,这两天突然被其中一个陷阱折腾一下:读一个文件,然后写到另外一个文件,前后两个文件居然不一样? ...

随机推荐

  1. websphere启用高速缓存导致问题

    环境:websphere 7 一个流程主页,里面include了上面这个页面,内部有一个iframe: 现象:项目发布在测试环境中,打开流程主页时,里面iframe内页显示不出来: 同样的jsp页面, ...

  2. Spring MVC学习一

    SpringMVC是一个基于DispatcherServlet的MVC框架,每一个请求最先访问的都是DispatcherServlet,DispatcherServlet负责转发每一个Request请 ...

  3. HRBUST 2064:萌萌哒十五酱的宠物~(最近公共祖先LCA)

    题意:一个n个点的树,询问某两点之间的简单路径,问路径上任选三边能否组成一个三角形. N<100000,权值<109 思路: 这里最神奇的思路过于以下这个: n个数,任意三个都不能组成三角 ...

  4. LeetCode OJ--Merge Sorted Array *

    http://oj.leetcode.com/problems/merge-sorted-array/ 两个有序数组A和B的归并排序,将结果存到A中.因为已知两数组长度且A的数组足够大,所以倒着处理, ...

  5. JSONP简单示例

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"><head>    < ...

  6. LibieOJ 6170 字母树 (Trie)

    题目链接 字母树 (以每个点为根遍历,插入到trie中,统计答案即可)——SamZhang #include <bits/stdc++.h> using namespace std; #d ...

  7. ELK之收集Java日志、通过TCP收集日志

    1.Java日志收集 使用codec的multiline插件实现多行匹配,这是一个可以将多行进行合并的插件,而且可以使用what指定将匹配到的行与前面的行合并还是和后面的行合并. 语法示例: inpu ...

  8. Jena+fuseki

    1.下载apache-jena-3.1.0.tar.gz,这个可以将ttl三元组文件或者xml文件加载 进入bin目录,执行./tdbloader2 --loc /path/for/database ...

  9. iOS开发 Coretext基本用法

    转至 http://blog.csdn.net/fengsh998/article/details/8691823 API接口文档. https://developer.apple.com/libra ...

  10. [反汇编练习] 160个CrackMe之031

    [反汇编练习] 160个CrackMe之031. 本系列文章的目的是从一个没有任何经验的新手的角度(其实就是我自己),一步步尝试将160个CrackMe全部破解,如果可以,通过任何方式写出一个类似于注 ...