linux应用程序接收文件,linux应用程序之----文件操作

文件操作

文件操作有两种方式,一种是利用Linux系统调用,它依赖于操作系统;另一种是利用C语言库函数,它不依赖于操作系统,在所有操作系统下面都是一样的。首先来看系统调用方式的文件操作。

1:创建文件

int creat (const char* pathname , mode_t mode)

1) mode_t 解释 :1 执行;2:可写:4:可读。

2)若成功返回文件描述符,出错返回-1

2:打开文件

int open(const char *path, int access, mode_t mode)

1)access 可取以下:

O_RDONLY只读打开

O_WRONLY只写打开

O_RDWR读写打开

O_APPEND         追加方式打开

O_CREAT           创建方式

O_NOBLOCK        非阻塞方式

2)int mode 只在O_CREAT模式下才需要设置。可用数字表示:1 执行;2:可写:4:可读。

3) 若成功返回文件描述符,出错返回-1

3:读文件

int  read(int fd , const void *buffer,  size_t length)

1) fd : 文件描述符,由creat以及open函数的返回值得到.

2)  *buffer 读取字符后的存储缓冲区

3) length  一次读取的字节数

4) 成功返回一次读取的实际字节数,失败返回-1

4:向文件写入字符

int  write(int fd , const void *buffer,  size_t length)

5) fd : 文件描述符,由create以及open函数的返回值得到.

6)  *buffer 写入字符的存储缓冲区

7) length  一次写入的字节数

8) 成功返回一次读取的实际字节数,失败返回-1

5: 关闭文件

int close (fd)

6:文件定位

int lseek(int fd , offset_t offset , int where)

where的取值如下:SEEK_SET ; SEEK_CUR ; SEEK_END三种。注意offset可以取负值,表示向前移动。操作成功后返回文件指针相对于文件头的位置。利用这一点,可以很轻松的计算一个文件的大小。只需调用  lseek(fd , 0 , SEEK_END),如果调用成功,其返回的就是文件的大小。

7:访问判断

有时需要知道某个文件的属性,就可以利用访问判断函数。其原型为:

int access(const char* pathname , int mode)

mode的取值,R_OK(可读) , W_OK(可写) , X_OK (可执行), F_OK(文件存在)。并且这些条件可以组合使用。如果判断的条件成立,那么返回0,否则只要有一个条件不符合,就返回-1.

下面介绍C语言库函数方式对文件的操作。在此之前,首先得明白三点。1:c语言中的文件一般分为两类(按存储方式划分)。一类是字符文件,一类是二进制的文件。(linux系统调用不区分这两类文件)2:ANSI C 标准中对文件的操作会首先在内存开辟一块缓冲空间,如对文件进行读操作,先把读到的内容放到缓冲区,再从缓冲区送到程序数据区。反过来对文件的写操作也是一样的,先把写的内容放到缓冲区区,等缓冲区满以后,在一起写入到文件中去。3:FILE 指针,应该是C语言为每一个打开的文件都设计的一个指针,里面包含了这个打开文件的很多信息。比如文件内部的指针位置等。

1打开文件

file*  fopen(const char*filename  const char*mode )

1)r   只读方式打开一个文本文件rb  只读方式打开一个二进制文件w   只写方式打开一个文本文件wb  只写方式打开一个二进制文件a   追加方式打开一个文本文件ab  追加方式打开一个二进制文件r+  可读可写方式打开一个文本文件rb+ 可读可写方式打开一个二进制文件w+  可读可写方式创建一个文本文件wb+ 可读可写方式生成一个二进制文件a+  可读可写追加方式打开一个文本文件ab+ 可读可写方式追加一个二进制文件

注意:要加上双引号,例如: fopen(argv[1],”rb”)

2)若打开成功,返回文件指针类型的结构,若失败,返回null

引申:file* 是一种文件指针,与char*,int*作对比,可知,它是一个指向文件的指针。它实际上是由系统定义的一个结构,该结构中含有文件名、文件状态和文件当前位置等信息。在编写源程序时不必关心file结构的细节。

2:关闭文件。

int   fclose(FILE *fp);

注意其返回值,返回0,正常关闭文件,否则即为异常。不过貌似很少看到有对这个函数进行返回值检测的,大概是关闭文件一般不会出现异常吧。

3: 单个字符读写操作

int    fgetc (fp);一个特例是getchar = fgetc(stdin)

返回值是读到的字符的ASCII码。如果已经到达文件尾部,那么读出的是EOF(-1)。注意EOF是一个整形量。

int   fputc (字符数据 , fp); 一个特例是putchar=fputc(字符数据,stdout)。如果写入字符正确,那么返回写入字符的ASCII码,否则返回EOF,表示出错。

4:字符串的操作

int  fputs(字符串数据,fp);特例是 puts(字符串数据)------成功返回0,出错返回非0;

char *fgets(字符串变量,n,fp);特例是gets(字符数据)-------这里的字符串变量用于保存读到的字符串。N是你预期读

取字符串长度加1.说明,如果遇到换行符,结束符,则读取结束,否则直到读取到n-1个字符后结束。成功,返回指向字符

串 的指针,可以用于嵌套使用。否则返回NULL指针。

5:块读写操作

int  fread(char *buffer , int  size  ,  int  count  ,  FILE *fp);

int  fwrite (char *buffer , int  size  ,  int  count  ,  FILE *fp);

这两个函数不解释!

6:格式化输入,输出。

fscanf(文件指针,格式,输入列表);特例是scanf

fprintf(文件指针,时隔,输出列表);特例是printf

7:文件内部读写指针操作

int  rewind(FILE *fp)

int  fseek(FILE *fp,signed long ,where);-----where  :  SEEK_SET;SEEK_CUR;SEEK_END

long  ftell(FILE *fp);返回文件内部读写指针现在距离文件头的位置。出错返回-1L。

8:路径获取

char * getcwd(buffer , size_t size).size是buffer大小的描述。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值