草庐IT

imap_close

全部标签

c++ - DELETE_ON_CLOSE 发生得太早

我正在尝试在另一台机器上创建一个进程,该进程在完成后会自行删除。我在CreateFile中使用DELETE_ON_CLOSE标志。这种方法有点流行,但我遇到了麻烦,因为我无法在它打开时执行它(预期但这是某些解决方案所做的)。为了解决这个问题,我尝试使用读取权限打开文件。DELETE_ON_CLOSE标志表示它应该只在所有指向它的指针都消失时才删除文件。我有一个指向它的读取指针,我关闭了写入句柄,文件被删除,使我打开的句柄不可读。任何其他解决方法将不胜感激。我还考虑过这样一种可能性,即由于这是一个远程文件系统,因此句柄可能会发生一些奇怪的事情。我无法修改我发送过来的可执行文件的代码,所以

c++ - 使用 FILE_FLAG_DELETE_ON_CLOSE 标志创建文件

在描述我的问题之前,这里是我正在编写的程序(IHExplorer.exe)的描述:这是一个C++应用程序。IHExplorer应用程序看起来尽可能像Windows资源管理器窗口。但有一个异常(exception),那就是从这个资源管理器窗口中启动文件会首先将它们解密到用户的临时文件夹,然后启动与文件扩展名关联的应用程序并在关闭时删除文件。我遇到的问题是文件关闭时自动删除。这是一个场景:用户在IHExplorer中双击加密的.txt文件。IHExplorer解密内存中的.txt文件,然后使用::CreateFile将其写入%TEMP%,它返回文件的句柄(IHExplorer必须至少保持此

c++ - QSqlQuery 内存问题。 QSqlQuery::exec() 和 QSqlDatabase::open()/close();

我正在检查我创建的应用程序的内存使用情况。它进行多次调用以从数据库(SQLite3)读取和写入值。我观察到以下内容:QSqlQuery::exec()使用一些KB的RAM来执行给定的查询,但在超出范围后不会释放内存。QSqlDatabase::open()和close()并不像文档中建议的那样帮助释放资源。如果有的话,close()会导致资源(至少是内存)在堆/堆栈上保持“受困”状态。例如,这是我用来访问数据库的典型代码段。QStringListvalues;db.open();QStringstrQuery="SELECTDISTINCT"+field+"FROM"+table+st

c++ - 忘记调用 std::ofstream close 函数会导致内存泄漏吗?

我只是好奇这个问题:忘记调用std::ofstreamclose函数会导致内存泄漏吗?我举以下例子来说明我的问题:usingnamespacestd;ofstreammyfile;myfile.open("C:\\report.html");myfile""通常,我们还应该在代码脚本的末尾调用myfile.close()。但是,如果我忘记调用close函数,会发生什么?会不会导致内存泄漏?我用linux中的memcheck和valgrind检查程序,都没有发现内存泄漏。那么不调用close函数会有什么副作用呢。 最佳答案 当您的st

c++ - MFC 应用程序终止时运行自定义代码 : d'tor or WM_CLOSE?

我有一个基于对话框的MFC应用程序,它需要停止WindowsWifi服务才能正常运行,但我想在我的应用程序退出时再次启用它。所以我想我应该将重启服务的代码放在主对话框类的析构函数中。现在我注意到其他人将他们应该在程序终止期间运行的代码放入WM_CLOSE消息处理程序中。这两种方式似乎都有效,但我想知道这两种方式是否有缺点。 最佳答案 对于基于MFC对话框的应用程序,您可以将最终代码放置到应用程序类InitInstance方法中,紧接在主对话框DoModal调用之后。对于其他MFC应用程序类型(MDI、SDI),最终代码通常放在Exi

c++ - 围绕 avcodec_open/close 的线程锁定

我有一个c++-cli代码,它使用capture从opencv中的文件夹捕获视频,然后使用cvqueryframe检索帧。然后我处理帧,一旦处理完所有帧,我就释放捕获。它工作正常但是当我尝试多线程时它给了我一个警告并且无法捕获文件夹中的一些视频并警告“avcodec_open/close()周围的线程锁定不足”。//foreachvideoinfolderdo{capture=cvCreateFileCapture(filename);while(1){img=cvqueryframe(capture)if!imgbreak;///processimg}cvreleasecapture

c++ - "cout<<(char*)NULL"在这里做 "close(1)"吗?

这个问题在这里已经有了答案:Whydoesstd::coutoutputdisappearcompletelyafterNULLissenttoit(3个答案)关闭8年前。在下面的代码中我使用了cout在这一行之后,我的程序没有在输出屏幕上打印任何内容。这是否意味着我已经完成了close(1)与cout这里?这里到底发生了什么?这是一个错误吗?请分享您的想法。#includeusingnamespacestd;voidf(){cout我在gcc和DevCpp编译器上都试过了,观察到相同的行为。

c++ - Windows Web Server 2008 中的事件 CTRL_CLOSE_EVENT 未调用 CtrlHandler

我有一个控制台应用程序,它使用SetConsoleCtrlHandler设置一个处理程序来处理和CTRL_CLOSE_EVENT。处理程序仅返回TRUE,这将导致出现一个对话框并提示用户继续关闭或取消。该软件在WindowsXPSP3和WindowsWebServer2008SP2上运行。在XP上,当单击控制台窗口上的“X”时,将调用我的控制处理程序并按预期出现提示。在Server2008上,关闭控制台窗口不会调用我的控制处理程序,应用程序会在没有提示的情况下关闭。为了检查控制处理程序是否设置正确,我为CTRL_C_EVENT添加了一个案例。我可以看到为Ctrl-C调用了代码。在Ser

c++ - 主区域 : "master region may not be closely nested inside of work-sharing or explicit task region" 的 OpenMP for 循环

我有以下代码,我认为它应该显示一个进度条来近似整个过程的进度(因为循环的每个并行线程应该以大致相同的速度进行)#pragmaompparallelforfor(longintx=0;x但是,我收到以下错误:warning:masterregionmaynotbecloselynestedinsideofwork-sharingorexplicittaskregion[enabledbydefault]现在,当我运行代码时,我确实得到了想要的结果。但我不喜欢警告。为什么这会给我一个警告,是否有更好的方法来完成此操作?谢谢! 最佳答案

c++ - std::ofstream::close() 实际上做了什么?

本题:Howtoprotectlogfromapplicationcrash?把我带到了另一个-std::ofstream::close()到底做了什么?我知道它调用flush(),这是一回事。但还有什么?关闭文件实际上是什么?编辑:让我重新表述一下我的问题-在调用close()期间是否对实际文件进行了任何物理操作,还是只是std::ofstream内部清理的东西? 最佳答案 除了刷新用户空间缓冲区,即flush(),close(2)在底层文件描述符上被调用。这取决于操作系统然后会发生什么,但很可能文件占用的实际存储空间没有任何变化