Linux中的C++代码留下的文件句柄

Vti*_*rum 2 c c++ linux

我正在尝试调试代码中的问题.我有一个持续运行的流程A,直到我要求它停止.

在AI内部执行以下操作:

  • mount partition/dev/sda1
  • open() //创建一个空文件X.
  • write() //给它写一些字节
  • close() //关闭文件
  • processFile() //执行一些操作
  • remove() //删除文件
  • umount/dev/sda1

注意我在上面的每个操作之后测试它是否成功或不是前进.当我这样做时,lsof | grep A它显示了进程A拥有的X的文件句柄.我也看到它有一个(已删除).这可以防止我卸载分区.为什么会发生这种情况?如何解决这个问题?

编辑:谢谢大家.这是代码的片段:

tarFileDesc = _pSysCall->open("test.tar", O_CREAT | O_RDWR | O_APPEND, 0777);    
 if (0 > tarFileDesc)
  return false;

 ... some logging here

 // Write http stream to tar file, istr is an argument to my function     
 int read_buffer_size = 0;     
 buffer = new char[4096];     
 while (!istr.eof() && count < content_length)
 {      
    if ((content_length - count) >= 4096)
        read_buffer_size = 4096;
    else
        read_buffer_size = content_length - count;

    memset(buffer, 0, 4096);
    istr.read(buffer, read_buffer_size);
    std::streamsize in_bytes = istr.gcount();
    if (istr.fail() || istr.bad())
    {
        status = false;
        break;
    }

    if (write(tarFileDesc, buffer, in_bytes) != in_bytes)
    {
        status = false;
        break;
    }
    count += in_bytes;
}
// Cleanup buffer
delete[] buffer;

if ((0 > tarFileDesc) && (0 != close(tarFileDesc)))
    return false;   

if (0 != system("tar C /test -xvf test.tar"))
    return false;

if (0 != remove("test.tar"))
      return false;
Run Code Online (Sandbox Code Playgroud)

注意我甚至尝试过打开,关闭和删除.但我仍然看到进程持有的句柄.

Mat*_*ner 5

问题在于以下几点:

if ((0 > tarFileDesc) && (0 != close(tarFileDesc)))
    return false;   
Run Code Online (Sandbox Code Playgroud)

这只会关闭文件描述符if tarFileDesc < 0.你的意思是如果tarFileDesc >= 0然后关闭它,因为它是一个有效的文件描述符,所以尝试将此代码更改为:

if ((0 > tarFileDesc) || (0 != close(tarFileDesc)))
    return false;
Run Code Online (Sandbox Code Playgroud)

这样,如果文件描述符无效,则返回false,否则如果无法关闭它则返回false.