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() ,至少能够保持内存占用不持续升高。

posted @ 2018-02-28 16:22  brifuture  阅读(3440)  评论(0编辑  收藏  举报