2015.2.26

星期四,阴天

今天的内容主要是文件IO

man 手册的分册:

man -f open 查看那些分册中有open
man 1 -- 普通的命令程序
man 2 -- 系统调用
man 3 -- 库函数

文件:操作系统将硬件抽象成文件
输入:将设备中的数据写进到内存
输出:将内存中的数据写出到设备

Linux的文件系统由两层结构构成:第一层是虚拟文件系统(VFS),第二层是各种不同的具体的文件系统

posix:可移植操作系统接口规范
API:用户编程接口

应用通过POSIX和GNU C LIB 变成 系统调用(可以访问系统):称这个接口为库函数

应用直接访问系统:系统调用

上层要访问系统需要先通过系统调用,

出错处理:

strerror():映射errno对应的错误信息:strerror(errno) ,error是全局变量
prerror();输出用户信息及errno对应的错误信息

printf("file to open:%s\n", strerror(error))
perror("file to open:")
上面两条语句的功能想同:file to open: no such file directory (后面的提示语句和程序功能相关)

Linux中文件主要分为6种:普通文件,目录文件,符号链接文件,管道文件,套接字文件和设备文件。

不带缓存的IO:文件IO
带缓存的IO:标准IO
写出去:Output
读进来:Input(相对于程序而言)

open();read();write():
需要包含下面几个头文件
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>

标准IO:封装了文件描述符和缓存机制

fseek和ftell == lseek;

文件IO的函数:
open(),read(),write(),lseek(),close();

当总字节数大于每次读写的字节数的时候,判断是否读写完成有两种简单的判别方法;
1.累加:(设总字节数=MAX)

while((nbyte = write(fd, buf, N)) > 0)
{
sum += nbyte;
if(sum == MAX)
{
break;
}
}

2.判读实际读到的字节数和设置的读字节数是否相等

while(1)
{
i = read(fd, buf, N);
write(fd, buf, i);
if(i != N)
{
break;
}
}

off_t lseek(int fd, off_t offset, int whence)

offset:相对于基点whence的偏移量,以字节为单位,正数表示向前移动,负数表示向后移动

获得文件的长度:
length = lseek(fd, 0, SEEK_END)//备注几个宏(SEEK_SET , SEEK_CUR , SEEK_END)

标准IO;
fopen(),fread(),fwrite(),fseek(),ftell(),fprintf(),fclose();

求文件的长度:fseek()和ftell()两个函数组合的程序功能相当于lseek();
FILE *fp;
if(fseek(fp, 0, SEEK_END) < 0)
{
perror("fseek error");
fclose(fp);
retrn 1;
}
length = ftell(fp);

求文件长度完整程序:

#include <stdio.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <errno.h>
#include <string.h>

int main(int atgc, char *argv[])
{
FILE *fp;
long length;

if(argc < 2)
{
fprintf(stdout,"usage: %s filename\n",argv[0]);
return 1;
}

if((fp = fopen(argv[1],"r")) == NULL)
{
fprintf(stderr,"fopen error: %s",strerror(erron));
return 1;
}

if(fseek(fp, 0, SEEK_END) < 0)
{
perror("fseek error");
fclose(fp);
return 1;
}

lingth = ftell(fp);

printf("the fiel size is %ld\n",length);

fclose(fp);
return 0;
}

***************************************************************************************************************************************************************
***************************************************************************************************************************************************************
**************************o*************************************************************************************************************************************
***************************************************************************************************************************************************************

文件IO和标准IO的更多相关文章

  1. 文件IO和标准IO的区别【转】

    一.先来了解下什么是文件I/O和标准I/O: 文件I/O:文件I/O称之为不带缓存的IO(unbuffered I/O).不带缓存指的是每个read,write都调用内核中的一个系统调用.也就是一般所 ...

  2. 文件IO与标准IO的区别

    文件IO与标准IO的区别 文件I/O就是操作系统封装了一系列函数接口供应用程序使用,通过这些接口可以实现对文件的读写操作,文件I/O是采用系统直接调用的方式,因此当使用这些接口对文件进行操作时,就会立 ...

  3. 8 . IO类-标准IO、文件IO、stringIO

    8.1 IO类 #include <iostream> //标准IO头文件  8.2 文件输入输出流 #include <fstream> //读写文件头文件 std::fst ...

  4. linux文件io与标准io

    文件IO实际是API,Linux对文件操作主要流程为:打开(open),操作(write.read.lseek),关闭(close). 1.打开文件函数open(): 涉及的头文件:  #includ ...

  5. 系统调用IO和标准IO

    目录 1. 系统调用IO(无缓冲IO) 系统调用 常用系统调用IO函数 open close read write lseek ioctl 2. 标准IO(带缓冲IO) 概述 缓冲与冲洗 常用标准IO ...

  6. 标准IO与文件IO 的区别【转】

    本文转载自:http://blog.sina.com.cn/s/blog_63f31f3401013jrn.html 先来了解下什么是标准IO以及文件IO. 标准IO:标准I/O是ANSI C建立的一 ...

  7. 标准IO与文件IO 的区别

    先来了解下什么是标准IO以及文件IO. 标准IO:标准I/O是ANSI C建立的一个标准I/O模型,是一个标准函数包和stdio.h头文件中的定义,具有一定的可移植性.标准IO库处理很多细节.例如缓存 ...

  8. 文件的概念、标准IO其一

    1.文件的概念 文件是一种存储在磁盘(掉电不丢失存储设备)上,掉电不丢失的一种存储数据的方式,文件在系统中有以下层次的结构来实现. 系统调用.文件IO.标准IO的关系如下: 2.linux系统的文件分 ...

  9. [APUE]标准IO库(上)

    一.流和FILE对象 系统IO都是针对文件描述符,当打开一个文件时,即返回一个文件描述符,然后用该文件描述符来进行下面的操作,而对于标准IO库,它们的操作则是围绕流(stream)进行的. 当打开一个 ...

随机推荐

  1. HTTP协议中PUT和POST使用区别 【转载】

    有的观点认为,应该用 POST来创建一个资源,用PUT来更新一个资源:有的观点认为,应该用PUT来创建一个资源,用POST来更新一个资源:还有的观点认为可以用PUT和 POST中任何一个来做创建或者更 ...

  2. hdu 1811 Rank of Tetris (并查集+拓扑排序)

    Rank of Tetris Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  3. 自动发牌(C#版)

    利用数组实现发牌过程 一副牌去掉大小王,还剩52张.一共东.南.西.北四家,每家随机发13张牌. 提示: 东.南.西.北四家用一维数组表示 每家的牌采用一维数组表示(13张)  花色:enum Sui ...

  4. ajax的data传参的两种方式

    ajax的data传参的两种方式 本文为转载. 1.[javascript] view plain copy /** * 订单取消 * @return {Boolean} 处理是否成功 */ func ...

  5. 采购订单限价(包含阶梯价)ME_PROCESS_PO_CUST

    为了能管控到钱财的每个环节,公司要求采购订单需要使用物料限价,当有报价低于先前的价格时,在采购订单保存时,更新最低限价 BADI:ME_PROCESS_PO_CUST process~item里做限价 ...

  6. Cassandra——类似levelDB的基于p2p架构的分布式NOSQL数据库

    C: Consistency 一致性 • A: Availability 可用性(指的是快速获取数据) • P: Tolerance of network Partition 分区容忍性(分布式) 1 ...

  7. BZOJ3689 异或之

    我们需要知道一个事实,trie树上是可以要求第k大的! 我们每个节点记个size值然后像其他数据结构一样维护就可以了 然后我们再搞个priority_queue什么的就好了,注意每个值会出现两次只要记 ...

  8. Tomcat配置虚拟主机的两种方式

    1.基于主机名的虚拟主机配置 在随意盘符下建立一个目录作为虚拟地址的目录.例如:F:\virtualhost1,在其下建立 test1.html,写入内容例如:test 在tomcat/conf/se ...

  9. 使用ContentProContentProvider共享生词本数据

    自定义ContentProvider需要在项目清单中注册: import android.content.ContentProvider;import android.content.ContentU ...

  10. Shell脚本:使用rsync备份文件/目录

    本文我们介绍一个shell脚本,用来使用rsync命令将你本地Linux机器上的文件/目录备份到远程Linux服务器上.使用该脚本会以交互的方式实施备份,你需要提供远程备份服务器的主机名/ip地址和文 ...