windows 系统会缓存开始菜单和文件资源管理器中的图标,导致即使重新打包并安装新版应用(含新图标),仍显示旧图标——尤其在 `c:\program files` 等受保护路径下更为明显。
该问题并非 Inno Setup 或 Launch4j 的缺陷,而是 Windows 图标缓存机制所致。当应用首次安装到 C:\Program Files 时,Windows 会将可执行文件的图标提取并缓存至系统图标数据库(如 C:\Users\
✅ 根本原因分析:
:\Program Files 是受保护路径,系统对其图标缓存行为更保守(例如复用先前已验证的签名/哈希关联图标),而 C:\Program Files (x86) 或自定义路径因权限模型不同,缓存刷新更及时。? 可靠解决方案(按推荐顺序):
强制清除 Windows 图标缓存(最有效)
以管理员身份运行 CMD 或 PowerShell,依次执行:
ie4uinit.exe -ClearIconCache
若无效,补充以下步骤(适用于 Windows 10/11):
taskkill /f /im explorer.exe del "%localappdata%\IconCache.db" /a start explorer.exe
避免缓存复用:变更关键标识符
在 Inno Setup 脚本中,确保每次更新都打破缓存关联:
Inno Setup 安装脚本增强实践
添加卸载前清理旧快捷方式与注册表项(防止残留缓存引用):
[Code]
procedure CurUninstallStepChanged(CurUninstallStep: TUninstallStep);
begin
if CurUninstallStep = usUninstall then begin
// 删除旧开始菜单项(触发图标缓存失效)
DeleteFile(ExpandConstant('{autoprograms}\MyApp.lnk'));
DeleteFile(ExpandConstant('{autodesktop}\MyApp.lnk'));
end;
end;⚠️ 注意事项:
总结:图标不更新本质是 Windows 的性能优化机制,而非安装工具缺陷。通过主动清除缓存 + 唯一化部署标识(AppId/文件名/快捷方式名),即可实现图标稳定更新,确保用户始终看到最新视觉标识。