QML 程序运行效率

同样的程序,在 Windows 下面启动时非常慢,而在 Linux 上启动时很快,一方面是因为 qml 界面的创建耗时不同,另一方面是因为读取文件的用时相差太大导致。

On Linux

在 Linux (deepin)上运行 Qt Quick 程序时,读取文件的用时:

On Windows

在 Windows 10 上运行相同的程序,读取文件的用时:

上述三个文件大小分别为:

  • SPVertexCode.vsh 1kb
  • SPFragCode.fsh 2kb
  • Craft.obj 598kb

可以看到,在 Windows 上面读取文件的耗时有 3 秒多,而且仅仅是读取 600K 大小的文件,所以导致程序启动时耗费的时间太多。
并且 Linux 是 VMware 中开的一个虚拟机,配置不高,但是读取文件耗时仅为 Windows 平台下的 1/10.

内存使用情况

另外还发现一个现象,同样的一份代码,编译后在 Linux 上运行时,占用内存约为 60M;
而在 Windows 10 上占用内存超过 100M。
并且随着运行时间的增加,使用内存逐渐增加,大约每 10s 增加 1M。

使用 QML Profile 分析 Windows 程序后发现是频繁调用函数导致的 heap 内存使用过高。所以在 QML 文件中使用定时器,每 5 秒运行一次
gc() ,至少能够保持内存占用不持续升高。

本博客由 BriFuture 原创,并在个人博客(WordPress构建) BriFuture's Blog 上发布。欢迎访问。
欢迎遵照 CC-BY-NC-SA 协议规定转载,请在正文中标注并保留本人信息。
原文地址:https://www.cnblogs.com/brifuture/p/8484298.html