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