码迷,mamicode.com
首页 > 系统相关 > 详细

8.Linux文件编程

时间:2016-02-14 09:09:41      阅读:326      评论:0      收藏:0      [点我收藏+]

标签:

8.Linux文件编程

文件描述符:

????在Linux系统中,所有打开的文件对应一个数字,这个数字我们称为:文件描述符。

下面我们通过下面的几个函数来入门:

技术分享

打开文件:

在命令行执行:man open.得到下面的信息。

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

我们从帮助文档知道:open函数的功能是:open and possibly create a file or device.该函数有两种形式存在:

int open(const char *pathname, int flags);

int open(const char *pathname, int flags, mode_t mode);

使用该函数需要包含的头文件:

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

open() 函数的返回值:the new file descriptor or -1 if an error occurred.

?

代码:open.c:

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

void main(){

????int fd;

????fd = open("/home/test.c",O_RDWR);

????if(fd<0){

????????printf("open file failed!\n");

????}

}

?

?

?

编译过程:

技术分享

?

如果文件不存在则创建:

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

void main(){

????int fd;

????fd = open("/home/wen",O_RDWR|O_CREAT,0755);

????if(fd<0){

????????printf("open file failed!\n");

????}

}

?

技术分享

?

?

?

创建文件:

我们从帮助文档知道:creat函数的功能是:open and possibly create a file or device.该函数有两种形式存在:

int creat(const char *pathname, mode_t mode);使用该函数需要包含的头文件:

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

creat 函数的返回值:the new file descriptor or -1 if an error occurred.

代码creat.c:

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

void main(){

????int fd;

????fd = creat("/home/wen",0755);

????if(fd<0){

????????printf("create file failed!\n");

????}

}

?

?

运行结果:

技术分享

?

关闭文件:

先在命令行执行:man close.部分截图如下。

技术分享

我们从上面的帮助文档知道,close函数的功能是close a file descriptor。函数的有一个参数就是文件描述符fd。使用该函数需要包含头文件unistd.h。至于该函数的返回值:返回0表示关闭成功。返回-1表示关闭异常。Appropriately:适当的,合适的。

close.c文件的代码:

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

#include <unistd.h>

void main(){

????int fd;

????int fod;

????fd = creat("/home/wen",0755);

????if(fd<0){

????????printf("create file failed!\n");

????}

????fod = open("/home/wen",O_RDWR);

????if(fod<0){

????????printf("open file failed!\n");

????}

????close(fod);

}

技术分享

?

?

读文件:

在命令行执行:man 2 read得到下面的信息:

技术分享

技术分享

技术分享

技术分享

我们从帮助文档知道read函数的功能是在一个文件描述符中读取内容。使用read函数需要包含unistd.h头文件。该函数有三个参数:

ssize_t read(int fd, void *buf, size_t count);

第一个个参数是文件描述符,第二个参数是读入的地方,第三个参数是读入的大小。如果读入的大小是0则返回0,如果读入的内容大于count,则返回的大小不确定,成功就返回读入的字节数,大小是count,放在缓冲区buf。

read.c的代码:

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

#include <unistd.h>

void main(){

????int fd;

????char buf[12];

????fd = open("/home/wen",O_RDWR);

????if(fd<0){

????????printf("open file failed!\n");

????}

????read(fd,buf,7);

????buf[7] = "\0";

????printf("buf is %s\n",buf);

????close(fd);

}

文件/home/wen的内容:

技术分享

?

运行结果:

技术分享

?

写文件

在命令行执行man 2 write,得到下面的信息:

技术分享

技术分享

技术分享

技术分享

从上面知道wirte的功能是向一个打开的文件写入数据,他的原型是:

ssize_t write(int fd, const void *buf, size_t count);需要包含的头文件unistd.h。如果写失败返回-1.功能是从buf里取出count个字节,写入到fd的文件描述符里。

?

write.c的代码:

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

#include <unistd.h>

void main(){

????int fd;

????char *buf = "1300436815";

????fd = open("/home/wen",O_RDWR);

????if(fd<0){

????????printf("open file failed!\n");

????}

????write(fd,buf,8);

????close(fd);

}

运行结果:

技术分享

技术分享

?

上面我们已经学习了对文件的读和写的两种操作,那么下面的这个函数能不能把我们写入的内容读出来呢?代码如下:

技术分享

运行的结果:

技术分享

我们看到,读出的内容根本不是我们想象的。这是因为文件读写指针的问题。因为我们是先写操作,此时执行完写后,文件读写指针已经在文件内容的末尾,再往下读,读出来就是我们想不到的。这就是我接下来要学习的了。

?

?

定位文件:

在命令行man 2 lseek得到下面的内容:

技术分享

技术分享

技术分享

技术分享

我们从上面的帮助文档知道lseek的功能是重新定位文件读写指针。原型:

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

需要包含的头文件:

#include <sys/types.h>

#include <unistd.h>

该函数的返回值是移动后的文件指针距离文件头的位置,如果失败则返回-1.他有三个参数。第一个参数是指定文件,offset是偏移量,整数向前,负数向后。whence只有三种取值:SEEK_SET、SEEK_CUR和SEEK_END。我们通过whence参数决定了指针开始移动的位置,而通过偏移量offset可以设置移动的大小。

我们在上一节的代码加上,代码如下:

?

?

?

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

#include <unistd.h>

void main(){

????int fd;

????char *buf = "1300436815";

????char mybuf[10];

????fd = open("/home/wen",O_RDWR);

????if(fd<0){

????????printf("open file failed!\n");

????}

????write(fd,buf,8);

?

????lseek(fd,0,SEEK_SET);//locate in beginning

?

????read(fd,mybuf,8);

????mybuf[8]="\0";

????printf("mybuf is %s\n",mybuf);

????close(fd);

}

运行结果:

技术分享

从上面的运行结果看到,我们要的效果出来了。

?

复制文件描述符:

在帮助文档里的信息:

技术分享

技术分享

技术分享

技术分享

复制文件描述符dup函数,他需要包含的头文件:

#include <unistd.h>

dup函数:

int dup(int oldfd);

int dup2(int oldfd, int newfd);

?

#define _GNU_SOURCE

#include <unistd.h>

?

int dup3(int oldfd, int newfd, int flags);

dup函数的功能是从一个旧的文件描述符,复制一个新的文件描述符。当我们使用的是dup()时候,如果成功返回值就是新的文件描述符,失败则是返回-1.

?

?

?

write.c的内容改为:

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

#include <unistd.h>

void main(){

????int fd;

????char *buf = "1300436815";

????char mybuf[10];

????fd = open("/home/wen",O_RDWR);

????if(fd<0){

????????printf("open file failed!\n");

????}

???? ?

????

????int mydup = dup(fd);

?

????write(mydup,buf,8);

????lseek(fd,0,SEEK_SET);//locate in beginning

?

????read(fd,mybuf,8);

????mybuf[8]="\0";

????printf("mybuf is %s\n",mybuf);

????close(fd);

}

运行的结果跟前面的一个,说明复制成功,如下:

技术分享

?

?

?

综合实例:文件复制:

在我们的linux中复制文件的命令是:cp sofile gotfile

我们实现的步骤是:1.打开源文件 2.打开目标文件 3.读出源文件的内容 4.将读出的内容写入到目标文件。这就实现了文件的复制了。

?

?

?

?

?

copy.c 的代码:

#include <sys/types.h>

#include <sys/stat.h>

#include <fcntl.h>

#include <unistd.h>

?

void main(int argc, char **argv){

????int fd_s;

????int fd_t;

????int count=0;

????char buf[512];

?

????//open source file

????fd_s = open(argv[1],O_RDONLY);

????//open target file

????fd_t = open(argv[2],O_RDWR | O_CREAT,0777);

????//read source file and write to the target file

????while((count =????read(fd_s,buf,512)) > 0){

????????write(fd_t,buf,count);

????}

????//close all file

????close(fd_s);

????close(fd_t);

}

?

?

?

执行的过程:

技术分享

source.c的内容:

技术分享

生成的target.c的内容:

技术分享

8.Linux文件编程

标签:

原文地址:http://www.cnblogs.com/FORFISH/p/5188608.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!