C语⾔open()函数:打开⽂件函数(转)
相关函数:read, write, fcntl, close, link, stat, umask, unlink, fopen
头⽂件:#include <sys/types.h>    #include <sys/stat.h>    #include <fcntl.h>
定义函数:
int open(const char * pathname, int flags);
int open(const char * pathname, int flags, mode_t mode);
函数说明:
参数 pathname 指向欲打开的⽂件路径字符串. 下列是参数flags 所能使⽤的旗标:
O_RDONLY 以只读⽅式打开⽂件
O_WRONLY 以只写⽅式打开⽂件
O_RDWR 以可读写⽅式打开⽂件. 上述三种旗标是互斥的, 也就是不可同时使⽤, 但可与下列的旗标利⽤OR(|)运算符组合.
O_CREAT 若欲打开的⽂件不存在则⾃动建⽴该⽂件.
fopen函数失败O_EXCL 如果O_CREAT 也被设置, 此指令会去检查⽂件是否存在. ⽂件若不存在则建⽴该⽂件, 否则将导致打开⽂件错误. 此外, 若
O_CREAT 与O_EXCL 同时设置, 并且欲打开的⽂件为符号连接, 则会打开⽂件失败.
O_NOCTTY 如果欲打开的⽂件为终端机设备时, 则不会将该终端机当成进程控制终端机.
O_TRUNC 若⽂件存在并且以可写的⽅式打开时, 此旗标会令⽂件长度清为0, ⽽原来存于该⽂件的资料也会消失.
O_APPEND 当读写⽂件时会从⽂件尾开始移动, 也就是所写⼊的数据会以附加的⽅式加⼊到⽂件后⾯.
O_NONBLOCK 以不可阻断的⽅式打开⽂件, 也就是⽆论有⽆数据读取或等待, 都会⽴即返回进程之中.
O_NDELAY 同O_NONBLOCK.
O_SYNC 以同步的⽅式打开⽂件.
O_NOFOLLOW 如果参数pathname 所指的⽂件为⼀符号连接, 则会令打开⽂件失败.
O_DIRECTORY 如果参数pathname 所指的⽂件并⾮为⼀⽬录, 则会令打开⽂件失败。注:此为Linux2. 2 以后特有的旗标, 以避免⼀些系统安全问题.
参数mode 则有下列数种组合, 只有在建⽴新⽂件时才会⽣效, 此外真正建⽂件时的权限会受到umask 值所影响, 因此该⽂件权限应该为(mode-umaks).
S_IRWXU00700 权限, 代表该⽂件所有者具有可读、可写及可执⾏的权限.
S_IRUSR 或S_IREAD, 00400 权限, 代表该⽂件所有者具有可读取的权限.
S_IWUSR 或S_IWRITE, 00200 权限, 代表该⽂件所有者具有可写⼊的权限.
S_IXUSR 或S_IEXEC, 00100 权限, 代表该⽂件所有者具有可执⾏的权限.
S_IRWXG 00070 权限, 代表该⽂件⽤户组具有可读、可写及可执⾏的权限.
S_IRGRP 00040 权限, 代表该⽂件⽤户组具有可读的权限.
S_IWGRP 00020 权限, 代表该⽂件⽤户组具有可写⼊的权限.
S_IXGRP 00010 权限, 代表该⽂件⽤户组具有可执⾏的权限.
S_IRWXO 00007 权限, 代表其他⽤户具有可读、可写及可执⾏的权限.
S_IROTH 00004 权限, 代表其他⽤户具有可读的权限
S_IWOTH 00002 权限, 代表其他⽤户具有可写⼊的权限.
S_IXOTH 00001 权限, 代表其他⽤户具有可执⾏的权限.
返回值:若所有欲核查的权限都通过了检查则返回0 值, 表⽰成功, 只要有⼀个权限被禁⽌则返回-1.
错误代码:
EEXIST 参数pathname 所指的⽂件已存在, 却使⽤了O_CREAT 和O_EXCL 旗标.
EACCESS 参数pathname 所指的⽂件不符合所要求测试的权限.
EROFS 欲测试写⼊权限的⽂件存在于只读⽂件系统内.
EFAULT 参数pathname 指针超出可存取内存空间.
EINVAL 参数mode 不正确.
ENAMETOOLONG 参数 pathname 太长.
ENOTDIR 参数pathname 不是⽬录.
ENOMEM 核⼼内存不⾜.
ELOOP 参数pathname 有过多符号连接问题.
EIO I/O 存取错误.
附加说明:使⽤ access()作⽤户认证⽅⾯的判断要特别⼩⼼, 例如在access()后再作open()空⽂件可能会造成系统安全上的问题.
范例
1 #include <unistd.h>
2 #include <sys/types.h>
3 #include <sys/stat.h>
4 #include <fcntl.h>
5 main()
6 {
7int fd, size;
8char s[] = "Linux Programmer!\n", buffer[80];
9    fd = open("/tmp/temp", O_WRONLY|O_CREAT);
10    write(fd, s, sizeof(s));
11    close(fd);
12    fd = open("/tmp/temp", O_RDONLY);
13    size = read(fd, buffer, sizeof(buffer));
14    close(fd);
15    printf("%s", buffer);
16 }