文件描述符:在linux系统中打开文件就会获得文件描述符,它是个很小的正整数。每个进程在PCB(Process Control Block)中保存着一份文件描述符表,文件描述符就是这个表的索引,每个表项都有一个指向已打开文件的指针。
文件指针:C语言中使用文件指针做为I/O的句柄。文件指针指向进程用户区中的一个被称为FILE结构的数据结构。FILE结构包括一个缓冲区和一个文件描述符。而文件描述符是文件描述符表的一个索引,因此从某种意义上说文件指针就是句柄的句柄(在Windows系统上,文件描述符被称作文件句柄)。
fclose()有缓冲,close()没缓冲!
fclose()高级I/O系统,close()低级!
fclose()好移植,close()不好!
fclose()有文件指针的,可以用文件指针来访问文件的,close()只能用一个整数来代表文件。
不带缓冲的 I/O 操作函数,直接针对文件描述符的,每调用一次函数可能都会触发一次系统调用,单次调用可能比较快捷。但是,对于需要频繁进行 I/O 操作的程序,频繁触发系统调用产生的消耗太大。
标准 I/O 库提供了带缓冲的 I/O 操作函数,这些函数围绕着一种叫做流(stream)的东西进行。当使用标准 I/O 库打开或创建一个文件时,系统提供了一个流与这个文件相关联。通过流的读入和输出完成所需要的 I/O操作。
标准 I/O 库使用一个 FILE 结构来管理流所需要的所有信息,包括:用于实际 I/O 的文件描述符、指向用于该流的缓冲区的指针、缓冲区的长度、当前在缓冲区中的字符数以及出错标志等等。指向 FILE 对象的指针我们可以称为文件指针。
标准 I/O 库为每个进程预定义了三个流:标准输入、标准输出和标准出错。这三个标准 I/O 流通过预定义文件指针 stdin、stdout 和 stderr 加以引用。这个三个文件指针定义在头文件 <stdio.h> 中。
例子:写入一个数字到创建的文件中
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <fcntl.h>
#define BUFFER_SIZE 1024
#define FILE_PATH "/file.txt"
/*
* 程序入口
* */
int main(int argc,char **argv)
{
int test_fd = -1;
int ret = 1;
int buffer = 1000;
int num = 0;
/*打开或创建源文件,并将文件长度截断为0*/
if((test_fd=open(FILE_PATH, O_RDWR|O_CREAT|O_TRUNC))==-1)
{
printf("Open %s Error\n",FILE_PATH);
exit(1);
}
/*写入一个数字*/
ret = write(test_fd, &buffer, sizeof(int));
if( ret < 0)
{
printf("write Error\n");
exit(1);
}
printf("write %d byte(s) data\n",ret);
/*将文件指针移到最开始处去读文件中写入的数字*/
lseek(test_fd, 0L, SEEK_SET);
ret= read(test_fd, &num, sizeof(int));
if(ret==-1)
{
printf("read Error\n");
exit(1);
}
printf("read %d byte(s) data,the number is %d\n", ret, num);
close(test_fd);
exit(0);
}
参考文献:http://blog.sina.com.cn/s/blog_6f8e766f0102wheh.html