fcntl函数使用(收藏)

功能:获取或者修改文件描述符的状态标志

表头文件

  #include <sys/types.h>
  #include <unistd.h>
  #include < fcntl.h >

编辑本段函数类型

  定义函数 int fcntl(int fd , int cmd,...);
  函数是 变参 函数,根据cmd来判断第三个参数,参见printf的运用

编辑本段参数介绍

1. 参数fd

  参数fd代表欲设置的文件描述词。

2. 参数cmd

  参数cmd代表打算操作的指令。
  有以下几种情况:
  F_DUPFD用来查找大于或等于参数arg的最小且仍未使用的 文件描述词 ,并且复制参数fd的文件描述词。执行成功则返回新复制的文件描述词。新描述符与fd共享同一文件表项,但是新描述符有它自己的一套 文件描述符 标志,其中FD_CLOEXEC文件描述符标志被清除。请参考 dup2 ()。
  F_GETFD取得close-on-exec 旗标 。若此旗标的FD_CLOEXEC位为0,代表在调用exec()相关函数时文件将不会关闭。
  F_SETFD 设置close-on-exec 旗标。该旗标以参数arg 的FD_CLOEXEC位决定。
  F_GETFL 取得文件描述词状态旗标,此旗标为open()的参数flags。
  F_SETFL 设置文件描述词状态旗标,参数arg为新旗标,但只允许O_APPEND、O_NONBLOCK和O_ASYNC位的改变,其他位的改变将不受影响。
  F_GETLK 取得文件锁定的状态。
  F_SETLK 设置文件锁定的状态。此时flcok 结构的l_type 值必须是F_RDLCK、F_WRLCK或F_UNLCK。如果无法建立锁定,则返回-1,错误代码为EACCES 或EAGAIN。
  F_SETLKW F_SETLK 作用相同,但是无法建立锁定时,此调用会一直等到锁定动作成功为止。若在等待锁定的过程中被信号中断时,会立即返回-1,错误代码为EINTR。
1. 复制一个现有的描述符(cmd=F_DUPFD). 
2. 获得/设置文件描述符标记(cmd=F_GETFD或F_SETFD). 
3. 获得/设置文件状态标记(cmd=F_GETFL或F_SETFL). 
4. 获得/设置异步I/O所有权(cmd=F_GETOWN或F_SETOWN). 
5. 获得/设置记录锁(cmd=F_GETLK , F_SETLK或F_SETLKW).

详细的可以查阅:

3. 参数lock指针

  参数lock指针为flock 结构指针,定义如下
  struct flock
  {
  short int l_type;
  short int l_whence;
  off_t l_start;
  off_t l_len;
  pid_t l_pid;
  };
  l_type 有三种状态:
  F_RDLCK 建立一个供读取用的锁定
  F_WRLCK 建立一个供写入用的锁定
  F_UNLCK 删除之前建立的锁定
  l_whence 也有三种方式:
  SEEK_SET 以文件开头为锁定的起始位置。
  SEEK_CUR 以目前文件读写位置为锁定的起始位置
  SEEK_END 以文件结尾为锁定的起始位置。
  返回值 成功则返回0,若有错误则返回-1,错误原因存于errno.

编辑本段功能介绍

  fcntl()用来操作 文件描述符 的一些特性。fcntl 不仅可以施加建议性锁,还可以施加强制锁。同时,fcntl还能对文件的某一记录进行上锁,也就是记录锁。

编辑本段函数返回值

  fcntl的返回值与命令有关。如果出错,所有命令都返回-1,如果成功则返回某个其他值。下列四个命令有特定返回值:F_DUPFD、F_GETFD、F_GETFL、F_GETOWN.第一个返回新的 文件描述符 ,接下来的两个返回相应标志,最后一个返回一个正的进程ID或负的 进程组 ID。

编辑本段使用实例

   [1]
  int flags;
  /* 设置为非阻塞*/
  if ((flags = fcntl(sock_descriptor, F_GETFL, 0)) < 0)
  {
  /* Handle error */
  }
  if (fcntl(socket_descriptor, F_SETFL, flags | O_NONBLOCK) < 0)
  {
  /* Handle error */
  }
  /* 设置为阻塞 */
  if ((flags = fcntl(sock_descriptor, F_GETFL, 0)) < 0)
  {
  /* Handle error */
  }
  if (fcntl(socket_descriptor, F_SETFL, flags & (~O_NONBLOCK)) < 0)
  {
  /* Handle error */
  }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值