系统调用(二)——open/close函数

1:open函数

查看man手册

man 2 open

函数原型

  • int open(const char *pathname,int flags); //打开一个已经存在的文件
  • int open(const char *pathname,int flags,mode_t mode); //如果打开文件没有文件需要创建文件时使用
  • int close(int fs);
  • int creat(const char *pathname,mode_t mode);
  1. pathname:文件路径名
  2. flags:文件打开方式
  3. mode:该参数使用的前提是参数2指定了0_CREAT。取值8进制数,用来描述文件的访问权限,rwx。、
    创建文件最终权限 = mode & ~umask
  4. 返回值:
    • 成功:打开文件所得到对应的文件描述符(整数)
    • 失败:-1,设置errno

常用参数

O_RDONLY、O_WRONLY、O_RDWR
O_APPEND(追加)、O_CREAT(创建)、O_EXCL(是否存在)、O_TRUNC(截断)、O_NONBLOCK(非阻塞)
创建文件时,指定文件访问权限。权限同时受umask影响。
结论为:文件权限 = mode & ~umask
使用头文件:<fcntl.h>

open常见错误

  1. 打开文件不存在
  2. 以写方式打开只读文件(打开文件没有对应权限)
  3. 以只写方式打开目录

C程序

使用open系统调用引入头文件为:#include<unistd.h>
O_RDONLY等宏的头文件为:#include<fcntl.h>

例如打开一个未存在的文件:

#include<stdio.h>
#include<unistd.h>
#include<fcntl.h>

int  main()
{
	int fd;
	fd = open("./a.txt",O_RDONLY | O_CREAT,0644);//打开方式为只读和创建,权限为rw-r--r--
	printf("fd = %d\n",fd);
	close(fd);
	return 0;
}

O_TRUNC清零

fd = open("./a.txt",O_RDONLY | O_CREAT | O_TRUNC,0644);

若a.txt文件中有内容,则打开的同时将文件数据清零。

补充知识点

  • errno的头文件为#include<errno.h>
  • #include<string.h>引入该文件就能使用strerror(errno)该方法会返回errno对应的错误描述的字符串

2:close函数

int close(int fd);

版权声明:本文为qq_45855825原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。