之前测试同事发现,执行程序的卸载操作后,显示卸载成功,但是到对应安装目录下看到有几个exe文件并没有被删除,仍然在目录中。要等待大约几分钟左右,这些文件才会实际被删除掉,在此期间无法对这些文件进行覆盖、修改、删除及运行等操作,应该是在此过程中文件一直处于被锁定状态。即出现了文件删除延迟的问题。卸载程序中删除文件使用的是DeleteFile API函数,估计该函数实现是异步的,从而出现这样的删除延迟问题。
删除延迟带来的问题是,当我重新运行安装包执行安装操作,由于有部分exe处于延迟删除状态被锁定,不能直接被覆盖掉,只能执行重启后覆盖,就需要重启机器完成安装,很是讨厌。
一开始以为是病毒或者杀毒软件引起的,后来到网上搜了一下,才知道Win7/Win8 确实有文件删除延迟的问题,这是系统本身的问题。可能是由于部分exe文件存在兼容性状态在运行,导致兼容性机制跑完才会真正的被删除掉。
解决办法是,将Application Experience和 Program Compatibility Assistant Service两个服务都设置为自动启动,并且将当前这两个服务启动起来。这样
本文探讨了Windows 7和8系统中出现的文件删除延迟问题,问题表现为卸载程序后,文件需要几分钟才能真正删除,期间无法进行其他操作。问题源于DeleteFile API函数的异步删除和系统兼容性机制。解决方法包括设置Application Experience和Program Compatibility Assistant Service服务为自动启动。同时,提供了通过代码调整这两个服务状态的参考代码。
订阅专栏 解锁全文
2365





