文件I/O

16 篇文章 0 订阅
14 篇文章 0 订阅

学习笔记,小白可以相互学习,大佬看到能告诉咱理解不对的地方就好了。


文件I/O不同于标准I/O是不带缓冲的,即是每个read和write都调用内核中的相应系统调用。

对于内核而言,所有的打开文件都是有文件描述符引用。文件描述符就是一个非负整数。


函数:

1.open

int open(const char *pathname,int flages)

int open(const char *pathname,int flages,mode_t mode)

int creat(const char *pathname,mode_t mode)

头文件:sys/types.h sys/stat.h fcntl.h

打开一个文件open()和创建一个文件create()成功返回文件描述符,失败返回-1,并设置errno。

creat()等价于open(pathname,O_CREAT | O_WRONLY | O_TRNUC,mode)

open()可以打开设备文件,但是不能创建设备文件,设备文件必须用mknod()创建

open的参数:

flash:

1.O_RDNOLY只读方式打开文件

2.O_WRNOLY只写方式打开文件

3.O_RDWR读写方式打开文件    //前面这三个参数互斥,即不能同时存在

4.O_CREAT如果文件不存在,则建立,并且设置mode

//不常用 O_EXCL如果使用O_CREAT是文件存在,则返回错误信息,这个参数可以检测文件是否存在

//不常用 O_NOCTTY使用本参数时,如果文件为终端,那么终端不可以作为调用open()系统调用的那个进程控制终端

5.O_TRUNC如果文件已经存在,那么删除原来文件中的数据(清空)

6.O_APPEND以添加方式打开文件,所以对文件的写操作都是在文件末尾进行的

mode:

被打开文件的存取权限,为8进制表示法。例如0777(满权限),只用在使用O_CREAT参数的时候才会用到。


2.close

#include<unistd.h>

int close(int files);

可以关闭一个打开的文件,调用成功返回0,出错返回-1,并设置errno


3.read

#include<unistd.h>

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

读取一个已经打开的文件中的数据,调用成功返回读取的字节数,如果到达文件末尾返回0,出错返回-1,并设置errno


4.write

#include<unistd.h>

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

向一个已经打开的可写文件中写入数据,调用成功返回写入的字节数,失败返回-1,并设置errno


5.lseek

#include<unistd.h>

#include<sys/types.h>

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

fd文件描述符,offset偏移量(单位byte),whence当前位置基点(SEEK_SET 文件开头,SEE_CUR当前位置, SEEK_END文件尾)

调用成功:文件当前位置,失败:-1
注意:lseek只对常规文件有效
#include<stdio.h>
#include <string.h>
#include <stdlib.h>
#include <strings.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
int main(int argc, char *argv[])
{
    if (argc < 3) {
        fprintf(stderr, "Usage: %s <src_file> <dest_file>\n",argv[0]);
return -1;
    }

    int fin;
    int fout;
    fin = open(argv[1],O_RDONLY);
    if(-1 == fin)
    {
     //   printf("file %s can't open",argv[1]);
perror("open file1");
  return -1;
    }
    if((fout = open(argv[2],O_WRONLY|O_CREAT|O_TRUNC, 0666)) == -1)
    {
        perror("open file2");
        return -1;
    }

    int ret;
    char buf[100];
    while(1)
    {
ret = read(fin, buf, sizeof(buf));
if (ret < 0) {
perror("read");
break;
}else if (ret == 0) {
printf("read file end!\n");
break;
}
if (ret != write(fout, buf, ret)) {
perror("write");
break;
}
    }

    close(fin);
    close(fout);
}

/*****************上下这两个代码都是实现copy功能**************************************/

#include<stdio.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<unistd.h>
#include<fcntl.h>
int main(int argc,char *argv[])
{
    if(argc < 3)
    {
        printf("将filename1中的内容拷贝到filename2中去\n");
        fprintf(stderr,"usage:%s filename1 filename2\n",argv[0]);
        return -1;
    }
    int fd;
    if( 0 > (fd = open(argv[1],O_RDWR)))
    {
        perror("open");
        return -1;
    }

    int fd1;
    if( 0 > (fd1 = open(argv[2],O_CREAT|O_RDWR|O_TRUNC,0664)))
    {
        perror("open");
        return -1;
    }

    char buf[100];
    int  ret;
    int r;
    while(1)
    {
        ret = read(fd,buf,sizeof(buf));
        if(ret < 0)
        {
            perror("read");
        }
        else if( 0 == ret)
        {
            printf("read file end\n");
            break;
        }
        
        r = write(fd1,buf,ret);
        if( ret != r)
        {
           perror("write");
           break;
        }
    }
    close(fd);
    close(fd1);
    return 0;
}

/*************下面是creat***********************************/

#include<stdio.h>
#include<sys/stat.h>
#include<sys/types.h>
#include<fcntl.h>
int main()
{
    int fd;
    if( 0 > (fd = creat("test.txt",644)))
    {
        perror("creat");
        return -1;
    }
    printf("fd = %d\n",fd);
    return 0;
}

/*************lseek**************************/

#include<stdio.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<unistd.h>
#include<fcntl.h>
int main(int argc,char *argv[])
{
    if(argc < 2)
    {
        fprintf(stderr,"usage:%s filename\n",argv[0]);
        return -1;
    }
    int fd;
    if( 0 > (fd = open(argv[1],O_RDONLY)))
    {
        perror("open");
        return -1;
    }

    lseek(fd,100,SEEK_SET);

    char buf[100];
    int  ret;
    while(1)
    {
        ret = read(fd,buf,sizeof(buf));
        if(ret < 0)
        {
            perror("read");
        }
        else if( 0 ==ret)
        {
            printf("read file end\n");
            break;
        }

        if( ret != write(1,buf,ret))
        {
           perror("write");
           break;
        }
    }
    close(fd);
    return 0;
}

/**********************mywrite函数的思想**************************/

#include<stdio.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<unistd.h>
#include<fcntl.h>
int mywrite(int fd);//将内容全部读入进去
int main(int argc,char *argv[])
{
    if(argc < 2)
    {
        fprintf(stderr,"usage:%s filename\n",argv[0]);
        return -1;
    }
    int fd;
    if( 0 > (fd = open(argv[1],O_RDONLY)))
    {
        perror("open");
        return -1;
    }

    char buf[100];
    int  ret;
    while(1)
    {
        ret = read(fd,buf,sizeof(buf));
        if(ret < 0)
        {
            perror("read");
        }
        else if( 0 ==ret)
        {
            printf("read file end\n");
            break;
        }

        if( ret != write(1,buf,ret))
        //if( ret != mywrite(fd))
        {
           perror("write");
           break;
        }
    }
    close(fd);
    return 0;
}

int mywrite(int fd)//将内容全部读入进去
{
    int ret;
    int buf[100];
    int count = 0;
    while( count < sizeof(buf))//如果没有全部读入则进行循环,直到全部读入
    {
        ret = write(fd,buf + count,sizeof(buf) - count);
        count = count +  ret;
    }
    return count;
}


/*************求能打开的最多文件数目:1024个*******************************/

#include<stdio.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
#include<unistd.h>
int main()
{
    int i = 3,a;
    while(1)
    {
        if( 0 > (a = open("11.c",O_CREAT | O_WRONLY | O_TRUNC,666)))
        {
            perror("open");
            break;
        }
        i++;
        printf("%d\n",i);
    }
    close(a);
    return 0;
}




  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值