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的更多相关文章
-
文件IO和标准IO的区别【转】
一.先来了解下什么是文件I/O和标准I/O: 文件I/O:文件I/O称之为不带缓存的IO(unbuffered I/O).不带缓存指的是每个read,write都调用内核中的一个系统调用.也就是一般所 ...
-
文件IO与标准IO的区别
文件IO与标准IO的区别 文件I/O就是操作系统封装了一系列函数接口供应用程序使用,通过这些接口可以实现对文件的读写操作,文件I/O是采用系统直接调用的方式,因此当使用这些接口对文件进行操作时,就会立 ...
-
8 . IO类-标准IO、文件IO、stringIO
8.1 IO类 #include <iostream> //标准IO头文件 8.2 文件输入输出流 #include <fstream> //读写文件头文件 std::fst ...
-
linux文件io与标准io
文件IO实际是API,Linux对文件操作主要流程为:打开(open),操作(write.read.lseek),关闭(close). 1.打开文件函数open(): 涉及的头文件: #includ ...
-
系统调用IO和标准IO
目录 1. 系统调用IO(无缓冲IO) 系统调用 常用系统调用IO函数 open close read write lseek ioctl 2. 标准IO(带缓冲IO) 概述 缓冲与冲洗 常用标准IO ...
-
标准IO与文件IO 的区别【转】
本文转载自:http://blog.sina.com.cn/s/blog_63f31f3401013jrn.html 先来了解下什么是标准IO以及文件IO. 标准IO:标准I/O是ANSI C建立的一 ...
-
标准IO与文件IO 的区别
先来了解下什么是标准IO以及文件IO. 标准IO:标准I/O是ANSI C建立的一个标准I/O模型,是一个标准函数包和stdio.h头文件中的定义,具有一定的可移植性.标准IO库处理很多细节.例如缓存 ...
-
文件的概念、标准IO其一
1.文件的概念 文件是一种存储在磁盘(掉电不丢失存储设备)上,掉电不丢失的一种存储数据的方式,文件在系统中有以下层次的结构来实现. 系统调用.文件IO.标准IO的关系如下: 2.linux系统的文件分 ...
-
[APUE]标准IO库(上)
一.流和FILE对象 系统IO都是针对文件描述符,当打开一个文件时,即返回一个文件描述符,然后用该文件描述符来进行下面的操作,而对于标准IO库,它们的操作则是围绕流(stream)进行的. 当打开一个 ...
随机推荐
-
jQuery stop()用法
jQuery stop()的用法: stop(true)等价于stop(true,false): 停止被选元素的所有加入队列的动画. stop(true,true):停止被选元素的所有加入队列的动画, ...
-
PHP无限极分类
当你学习php无限极分类的时候,大家都觉得一个字“难”我也觉得很难,所以,现在都还在看,因为工作要用到,所以,就必须得研究研究. 到网上一搜php无限极分类,很多,但好多都是一个,并且,写的很乱, ...
-
es安装
1,安装java(至少1.8) yum install -y java java -version 在/etc/profile追加: JAVA_HOME=/usr/java/jdk1..0_45 PA ...
-
【原创】leetCodeOj ---Convert Sorted List to Binary Search Tree 解题报告
原题地址: https://oj.leetcode.com/problems/convert-sorted-list-to-binary-search-tree/ 题目内容: Given a sing ...
-
【css3网页布局】flex盒子模型
1.0 前言 网页布局(layout)是CSS的一个重点应用. 经典布局类型: 布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊 ...
-
SQL SUM() 函数
SUM() 函数 SUM 函数返回数值列的总数(总额). SQL SUM() 语法 SELECT SUM(column_name) FROM table_name SQL SUM() 实例 我们拥有下 ...
-
SSL backend error when using OpenSSL pycurl install error
centos7 pip install pycurl 错误 pip uninstall pycurl export PYCURL_SSL_LIBRARY=nss pip install pycurl ...
-
Ionic下的JPush缺少统计代码问题解决方法
用Ionic打包apk后安装到手机,收到缺少统计代码的提示,解决方法如下: 1. 找到了 platforms/android/src/com/ionichina/ioniclub/MainActiov ...
-
leetcode34. Find First and Last Position of Element in Sorted Array
二分查找不只是查找,还可以根据需求添加条件进行查找,比如这个题,左端点的条件就是边界点或者小于target,右端点的条件就是!=size()或者大于.根据这个找到查找的条件
-
spring boot + slf4j + log4j配置
https://docs.spring.io/spring-boot/docs/1.5.6.RELEASE/reference/htmlsingle/#boot-features-logging ht ...