Qt 无法识别某些字体导致程序启动失败
有用户反馈启动程序时,没有出现 UI 界面,程序跟 “闪退了一样”,查看日志,没有发现闪退或者报错异常,后面远程用户电脑并尝试解决
研究分析:在用户电脑上运行 debug 包,会出现 qt.qpa.fonts:Unable to enumerate family... 错误
初步怀疑是 windows 字体的问题,程序使用的 Qt 框架可能无法识别这些字体,后面进一步定位问题,发现程序主界面在调用 show() 函数时卡住并闪退,这一步在网络连接之前,故先排除网络方面的问题
网络搜索相关 bug 反馈,查看到类似帖子:https://bugreports.qt.io/browse/QTBUG-85683
当前程序使用的也是 Qt 5.15.0 版本,与该问题一样,因升级 Qt 版本需要时间并要通过验证和测试,所以可以先清除 Qt 无法识别的字体,后续再升级 Qt 版本
解决方案:将用户的字体包(C:/Windows/Fonts)暂时拷贝到我们的电脑上以备复现,再将用户的字体库删除了一遍,仅保留 windows 默认的字体,再启动程序,可以启动成功,因用户反馈这些字体现在用不到了,所以目前没有什么问题
后续:在现有的 windows 10 和 windows 11 上安装了用户的字体包,没有复现 :(