linux文件I/O编程

linux文件访问有系统调用C库函数两种方式。主要介绍系统调用

1.int creat(const char * pathname, mode_tmode);//创建文件
 pathname指向欲建立的文件路径或者文件名
 mode创建模式(rwx) S_IRUSR可读4; S_IWUSR可写2; S_IXUSR可执行1; S_IRWXUSR 7;无权限为0。
 creat()会返回新的文件描述词,若有错误发生则会返回-1,并把错误代码设给errno。描述符本质是非负整数范围0~1024。
 
 
 
  #include 
    
    
     
     
  #include 
     
     
      
      
  #include
      
      
       
       
  #include
       
       
        
        
  #include
        
        
          void creat_file(char *filename) { if(creat(filename ,0755)<0) { printf("创建文件失败\n"); } else printf("创建%s成功\n",filename); } int main(int argc,char *argv[]) { int i=0; if(argc<2) { printf("你没有输入文件名,请重试\n"); exit (EXIT_FAILURE); } for(i=0;i 
          
        
       
       
      
      
     
     
    
    

2.int open( const char * pathname, int flags);//打开文件
 int open( const char * pathname,int flags, mode_t mode);

 pathname 指向欲打开的文件路径或文件名;mode打开方式;flags打开标志参数有以下多种:

   O_RDONLY 以只读方式打开文件
 O_WRONLY 以只写方式打开文件
 O_RDWR 以可读写方式打开文件。上述三种旗标是互斥的,也就是不可同时使用,但可与下列的旗标利用OR(|)运算符组合。
 O_CREAT 若欲打开的文件不存在则自动建立该文件。
 O_EXCL 如果O_CREAT 也被设置,此指令会去检查文件是否存在。文件若不存在则建立该文件,否则将导致打开文件错误。

      此外,若O_CREAT与O_EXCL同时设置,并且欲打开的文件为符号连接,则会打开文件失败。  

   O_APPEND 当读写文件时会从文件尾开始移动,也就是所写入的数据会以附加的方式加入到文件后面。
 O_NONBLOCK 以不可阻断的方式打开文件,也就是无论有无数据读取或等待,都会立即返回进程之中。
 O_NDELAY 同O_NONBLOCK。

   不常用的有:

   O_NOCTTY 如果欲打开的文件为终端机设备时,则不会将该终端机当成进程控制终端机。
 O_TRUNC 若文件存在并且以可写的方式打开时,此旗标会令文件长度清为0,而原来存于该文件的资料也会消失。

   O_SYNC 以同步的方式打开文件。
 O_NOFOLLOW 如果参数pathname 所指的文件为一符号连接,则会令打开文件失败。
 O_DIRECTORY 如果参数pathname 所指的文件并非为一目录,则会令打开文件失败。   

  #include <stdio.h>
  #include <stdlib.h>
  #include<sys/types.h>
  #include<sys/stat.h>
  #include<fcntl.h>
  int main(int argc,char *argv[])
  {
    int fd;
    if(argc<2)
    {
       puts("输入想要打开的文件名\n");
       exit (1);  
    }
    if((fd=open(argv[1],O_CREAT|O_RDWR,0755)<0)
    {  
       perror("打开失败\n");
       exit (1);
    }
    else
       printf("open file %d success!\n",fd);
    close(fd); //必不可少
    exit (0);
 }

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

函数说明
read()会把参数fd 所指的文件读count个字节到buf指针所指的内存中。若参数count为0,则read()不会有作用并返回0。返回值为实际读取到的字节数,如果返回0,表示已到达文件尾或是无可读取的数据,此外文件读写位置会随读取到的字节移动。
附加说明
如果顺利read()会返回实际读到的字节数,最好能将返回值与参数count 作比较,若返回的字节数比要求读取的字节数少,则有可能读到了文件尾、从管道(pipe)或终端机读取,或者是read()被信号中断了读取动作。当有错误发生时则返回-1,错误代码存入errno中,而文件读写位置则无法预期。
错误代码
EINTR 此调用被信号所中断。
EAGAIN 当使用不可阻断I/O 时(O_NONBLOCK),若无数据可读取则返回此值。
EBADF 参数fd 非有效的文件描述词,或该文件已关闭。
 int write (int fd,const void * buf,size_t count);

函数说明
write()会把参数buf所指的内存中的count个字节写入参数fd所指的文件内。当然,文件读写位置也会随之移动。
返回值
如果顺利write()会返回实际写入的字节数。当有错误发生时则返回-1,错误代码存入errno中。
错误代码
EINTR 此调用被信号所中断。
EAGAIN 当使用不可阻断I/O 时(O_NONBLOCK),若无数据可读取则返回此值。
EADF 参数fd非有效的文件描述词,或该文件已关闭。
 int lseek(int fd,offset_t offset ,int whence);

函数说明
每一个已打开的文件都有一个读写位置,当打开文件时通常其读写位置是指向文件开头,若是以附加的方式打开文件(如O_APPEND),则读写位置会指向文件尾。当read()或write()时,读写位置会随之增加,lseek()便是用来控制该文件的读写位置。参数fd 为已打开的文件描述符,参数offset 为根据参数whence来移动读写位置的位移数。
参数
whence为下列其中一种:
SEEK_SET 参数offset即为新的读写位置。
SEEK_CUR 以目前的读写位置往后增加offset个位移量。
SEEK_END 将读写位置指向文件尾后再增加offset个位移量。
当whence 值为SEEK_CUR 或SEEK_END时,参数offet允许负值的出现。
下列是教特别的使用方式:
1) 欲将读写位置移到文件开头时:lseek(int fd,0,SEEK_SET);
2) 欲将读写位置移到文件尾时:lseek(int fd,0,SEEK_END);可以计算文件长度
3) 想要取得目前文件位置时:lseek(int fd,0,SEEK_CUR);
返回值
当调用成功时则返回目前的读写位置,也就是距离文件开头多少个字节。若有错误则返回-1,errno 会存放错误代码。
附加说明
Linux系统不允许lseek()对tty装置作用,此项动作会令lseek()返回ESPIPE。
 int access(const char *pathname,int mode);//文件权限判断

  mode是要判断的权限:R_OK可读; W_OK; X_OK; F_OK文件存在。成功返回0,否则返回-1。

附加说明
使用access()作用户认证方面的判断要特别小心,例如在access()后再作open()空文件可能会造成系统安全上的问题。
最后:
范例
#include<unistd.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
main()
{
int fd,size;
char s [ ]=”Linux Programmer!\n”,buffer[80];
fd=open(“/tmp/temp”,O_WRONLY|O_CREAT);
write(fd,s,sizeof(s));
close(fd);
fd=open(“/tmp/temp”,O_RDONLY);
size=read(fd,buffer,sizeof(buffer));
close(fd);
printf(“%s”,buffer);
}
执行
Linux Programmer!



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值