三种文件句柄之间的转换


              <- _fdopen <-                        <- _open_osfhandle
FILE*                               int fid                                                     OS  HANDLE
             -> _fileno ->                        -> _get_osfhandle

第一种FILE*是C语言里标准的文件指针。我们常说的stdin, stdout, stderr就是FILE*类型的

第二种是POSIX接口中的文件句柄。MSVC里提供的函数_open就返回这个句柄。(顺便提一句,Windows也是号称遵循POSIX标准的,虽然改的乱七八糟,毕竟还是有)。 其实stdin对应的句柄就是0, stdout是1,stderr是2。如果你windows帮助里查"重定向” 就能查到这几个数字。

第三中HANDLE是Windows 的API CreateFile返回的。

当然,最后前两种调用最后都会使用最后的CreateFile来打开文件,也就是在无论任何时候,OS HANDLE总是存在的。但是,使用HANDLE总是比使用前两种来的罗嗦,想一想Windows API那动辄十几的调用参数就够汗一把的。

为什么我们要在这几种句柄中间进行转换,我现在想到的原因有二:
1. 有些功能,比如获取文件的长度,没有对应的操作FILE*的函数能做的。函数POSIX函数_filelength就可以做到
2. 如果调用不同的函数库,不同的库可能要求的参数类型

文件指针/句柄(FILE*)、文件描述符(fd)以及 文件路径(filepath)的相互转换(完整版,收集,整理)

定义

FILE *fp;  //文件指针、句柄
int    fd;  //文件描述符
char pathname[1024];  //文件路径

1、pathname  --> fp,fd

fp = fopen(pathname,"r");
fd = open(pathname,O_RDONLY);

2、fd -->  fp,pathname

fp = fdopen(fd,"r");

下面这个函数能够实现由fd转成pathname,

int get_pathname_from_fd(int fd, char pathname[], int n)
{
    char buf[1024];
    pid_t pid;
    
    bzero(buf, sizeof(buf));
    pid = getpid();
    snprintf(buf, sizeof(buf), "/proc/%i/fd/%i", pid, fd);
    return readlink(buf, pathname, n);
}

3、fp --> fd,pathname

fd = fileno(fp);

由于有get_pathname_from_fd作基础,很容易实现fp->pathname,

int get_pathname_from_fp(FILE *fp, char pathname[], int n)
{
  return get_pathname_from_fd(fileno(fp),pathname,n);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值