笔记3-1: open/close/create 函数
open/close/create函数:
原型:
#include <fcntl.h>
int open(const char * pathname, into oflag, … /*mode_t mode*/ );
pathname为需要打开或者创建的文件名。
oflag参数说明此函数的多个选项。
mode是可选参数,用于同步输入输出选项的一部分。
一、oflag
oflag用来说明open的多个选项。用下面一个或者多个常量标志通过或运算来构成oflag参数。这些参量都在<fcntl.h>中定义:
下面三个常量必须要指定,并只可以指定一个:
|
O_RDONLY |
只读打开 |
|
O_WRONLY |
只写打开 |
|
O_RDWR |
读写方式打开 |
下面常量是可选择的:
|
O_APPEND |
每次写时,都在文件尾部进行追加。 |
|
O_CREAT |
如果文件不存在,则创建它。这时需要第三个参数。 |
|
O_EXCL |
如果指定了O_CREAT,文件存在是创建文件则出错,不存在是则创建文件。可以使测试文件存在与创建文件原子操作。 |
|
O_TRUNC |
文件存在,只写或者读写打开,并将长度截取为0 |
|
O_NOCTTY |
如果是终端设备,不将该设备分配为进程的控制终端。 |
|
O_NONBLOCK |
文件是一个FIFO,一个块特殊文件或者字符特殊文件。 |
下面常数用于文件输入输出同步,也是可选的一部分:
|
O_DSYNC |
每次写入都等待物理I/O操作完成,如果写操作不影响刚写部分的读取操作的话,则不等待。 |
|
O_RSYNC |
read操作等待,等待同一部分的写操作完成。 |
|
O_SYNC |
每次写入都等待物理I/O操作完成,包括write的属性更新 |
|
O_FSYNC |
等效与O_SYNC,FreeBSD与Mac OS X有定义。 |
注意:FreeBSD与Mac OS X不支持O_DSYNC与O_RSYNC。
二、mode
mode参数表示创建文件时,指定的文件访问权限。
close函数:
原型:
#include <unistd.h>
int close(int filedes);
用于关闭一个由open打开的描述符。
create函数:
原型:
#include <fcntl.h>
int create(const char * pathname, mode_t mode);
该函数用于创建一个新文件,等效于
open(pathname, O_WRONLY | O_CREAT | O_TRUNC, mode);
浙公网安备 33010602011771号