在SOUI3中使用预编译XML
传统的XML文件通常是utf8编码的文本文件。使用文本文件好处在于方便查阅及修改。
SOUI使用XML做为布局描述语言,所有的布局资源都是XML。文本文件格式自由,XML解析器需要对文件中的字符逐个解析,最后生成DOM树。
解析过程还要判断各种格式合法性以及特殊符号的转义等工作,导致性能方面很难进一步提高。SOUI中采用了现在开源XML解析库中非常优秀的pugixml作为解析器,根据作者的统计,其解析XML的速度甚至和strlen方法差不多。
考虑到文本XML解析过程本身相对复杂,我们在SOUI3中实现了一种XML预编译的二进制格式。
在二进制格式中,第一部分是文件头,第二部分是字符串表,第三部分是DOM结构。
通过将文本XML转换成二进制XML,可以显著提高XML的解析速度。
下面是重复解析一个25K的XML文件50次消耗时长在debug及release模式下的对比:
debug模式:
2 0.000741 14604 demod.exe text xml: 433, bin xml:230
3 0.001585 14604 demod.exe text xml: 460, bin xml:259
4 0.002432 14604 demod.exe text xml: 471, bin xml:293
5 0.003319 14604 demod.exe text xml: 456, bin xml:323
6 0.004165 14604 demod.exe text xml: 487, bin xml:242
7 0.005081 14604 demod.exe text xml: 476, bin xml:334
8 0.005917 14604 demod.exe text xml: 461, bin xml:271
9 0.006747 14604 demod.exe text xml: 457, bin xml:275
10 0.007547 14604 demod.exe text xml: 458, bin xml:245
11 0.008352 14604 demod.exe text xml: 447, bin xml:256
12 0.009104 14604 demod.exe text xml: 445, bin xml:215
13 0.010045 14604 demod.exe text xml: 483, bin xml:312
14 0.010903 14604 demod.exe text xml: 465, bin xml:287
15 0.011820 14604 demod.exe text xml: 490, bin xml:283
16 0.012670 14604 demod.exe text xml: 515, bin xml:232
17 0.013396 14604 demod.exe text xml: 441, bin xml:211
18 0.014200 14604 demod.exe text xml: 435, bin xml:243
19 0.015056 14604 demod.exe text xml: 437, bin xml:297
20 0.015985 14604 demod.exe text xml: 505, bin xml:293
21 0.016775 14604 demod.exe text xml: 442, bin xml:219
22 0.017837 14604 demod.exe text xml: 581, bin xml:363
23 0.018832 14604 demod.exe text xml: 573, bin xml:290
24 0.019714 14604 demod.exe text xml: 531, bin xml:223
25 0.020532 14604 demod.exe text xml: 459, bin xml:231
26 0.021473 14604 demod.exe text xml: 582, bin xml:264
27 0.022232 14604 demod.exe text xml: 417, bin xml:248
28 0.022893 14604 demod.exe text xml: 413, bin xml:180
29 0.023523 14604 demod.exe text xml: 386, bin xml:179
30 0.024150 14604 demod.exe text xml: 385, bin xml:177
31 0.025061 14604 demod.exe text xml: 476, bin xml:332
32 0.025818 14604 demod.exe text xml: 455, bin xml:253
33 0.026476 14604 demod.exe text xml: 408, bin xml:182
34 0.027109 14604 demod.exe text xml: 388, bin xml:178
35 0.027741 14604 demod.exe text xml: 387, bin xml:178
36 0.028402 14604 demod.exe text xml: 404, bin xml:193
37 0.029055 14604 demod.exe text xml: 387, bin xml:197
38 0.029685 14604 demod.exe text xml: 386, bin xml:178
39 0.030313 14604 demod.exe text xml: 385, bin xml:178
40 0.030941 14604 demod.exe text xml: 386, bin xml:177
41 0.031570 14604 demod.exe text xml: 385, bin xml:180
42 0.032197 14604 demod.exe text xml: 386, bin xml:177
43 0.032923 14604 demod.exe text xml: 408, bin xml:245
44 0.033569 14604 demod.exe text xml: 390, bin xml:186
45 0.034224 14604 demod.exe text xml: 385, bin xml:208
46 0.034852 14604 demod.exe text xml: 386, bin xml:178
47 0.035479 14604 demod.exe text xml: 386, bin xml:178
48 0.036104 14604 demod.exe text xml: 384, bin xml:176
49 0.036730 14604 demod.exe text xml: 384, bin xml:177
50 0.037352 14604 demod.exe text xml: 384, bin xml:174
2 0.000423 636 demo.exe text xml: 191, bin xml:167
3 0.000856 636 demo.exe text xml: 198, bin xml:158
4 0.001449 636 demo.exe text xml: 226, bin xml:260
5 0.001936 636 demo.exe text xml: 226, bin xml:159
6 0.002392 636 demo.exe text xml: 200, bin xml:158
7 0.002865 636 demo.exe text xml: 197, bin xml:157
8 0.003324 636 demo.exe text xml: 203, bin xml:162
9 0.003779 636 demo.exe text xml: 202, bin xml:158
10 0.004216 636 demo.exe text xml: 209, bin xml:150
11 0.004710 636 demo.exe text xml: 191, bin xml:220
12 0.005302 636 demo.exe text xml: 274, bin xml:190
13 0.005785 636 demo.exe text xml: 207, bin xml:191
14 0.006211 636 demo.exe text xml: 190, bin xml:155
15 0.006640 636 demo.exe text xml: 202, bin xml:156
16 0.007081 636 demo.exe text xml: 207, bin xml:155
17 0.007526 636 demo.exe text xml: 201, bin xml:157
18 0.007937 636 demo.exe text xml: 175, bin xml:170
19 0.008326 636 demo.exe text xml: 180, bin xml:145
20 0.008704 636 demo.exe text xml: 175, bin xml:139
21 0.009085 636 demo.exe text xml: 174, bin xml:143
22 0.009468 636 demo.exe text xml: 175, bin xml:144
23 0.009830 636 demo.exe text xml: 174, bin xml:143
24 0.010209 636 demo.exe text xml: 173, bin xml:142
25 0.010605 636 demo.exe text xml: 175, bin xml:141
26 0.011005 636 demo.exe text xml: 173, bin xml:175
27 0.011397 636 demo.exe text xml: 162, bin xml:173
28 0.011732 636 demo.exe text xml: 162, bin xml:128
29 0.012039 636 demo.exe text xml: 139, bin xml:124
30 0.012349 636 demo.exe text xml: 140, bin xml:126
31 0.012658 636 demo.exe text xml: 139, bin xml:126
32 0.012967 636 demo.exe text xml: 139, bin xml:126
33 0.013273 636 demo.exe text xml: 138, bin xml:125
34 0.013581 636 demo.exe text xml: 139, bin xml:125
35 0.013891 636 demo.exe text xml: 139, bin xml:127
36 0.014197 636 demo.exe text xml: 138, bin xml:124
37 0.014506 636 demo.exe text xml: 138, bin xml:127
38 0.014818 636 demo.exe text xml: 139, bin xml:126
39 0.015142 636 demo.exe text xml: 143, bin xml:132
40 0.015466 636 demo.exe text xml: 140, bin xml:134
41 0.015774 636 demo.exe text xml: 139, bin xml:126
42 0.016082 636 demo.exe text xml: 139, bin xml:126
43 0.016420 636 demo.exe text xml: 139, bin xml:155
44 0.016733 636 demo.exe text xml: 142, bin xml:127
45 0.017071 636 demo.exe text xml: 138, bin xml:156
46 0.017381 636 demo.exe text xml: 139, bin xml:127
47 0.017691 636 demo.exe text xml: 139, bin xml:127
48 0.017996 636 demo.exe text xml: 138, bin xml:125
49 0.018305 636 demo.exe text xml: 138, bin xml:127
50 0.018611 636 demo.exe text xml: 139, bin xml:123
convert d:\work\soui3.git\demo\uires\anim\love.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\anim\rotate.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\anim\slide_hide.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\anim\slide_show.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\translation files\lang_cn.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\uidef\init.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\valueAni\alpha.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\valueAni\color.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\values\color.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\values\skin.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\values\string.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\values\template.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\calendar.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_formatmsg.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_main.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_set_skin.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_skiatext.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_skinset.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_tip.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_wrap_content.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\love.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\menu_lv.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\menu_test.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\menuex_test.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_about.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_ani3.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_animator.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_ctrls.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_layout.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_misc.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_script.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_skia.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_treeview.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_webkit.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\xml\treectrl.xml to bin return succeed!
convert d:\work\soui3.git\demo\uires\anim\love.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\anim\rotate.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\anim\slide_hide.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\anim\slide_show.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\translation files\lang_cn.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\uidef\init.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\valueAni\alpha.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\valueAni\color.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\values\color.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\values\skin.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\values\string.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\values\template.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\calendar.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_formatmsg.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_main.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_set_skin.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_skiatext.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_skinset.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_tip.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\dlg_wrap_content.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\love.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\menu_lv.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\menu_test.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\menuex_test.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_about.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_ani3.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_animator.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_ctrls.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_layout.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_misc.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_script.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_skia.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_treeview.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\page_webkit.xml to xml return succeed!
convert d:\work\soui3.git\demo\uires\xml\treectrl.xml to xml return succeed!
在SOUI3中使用预编译XML的更多相关文章
- DelphiXE10.1项目中增加预编译的方法
操作: 菜单选择Proceject->Options->Delphi Compilerz在Conditional Defines(第一行)中添加预编译标识.例:VCL代码:uses{$IF ...
- iOS中的预编译指令的初步探究
目录 文件包含 #include #include_next #import 宏定义 #define #undef 条件编译 #if #else #endif #if define #ifdef #i ...
- C中的预编译宏定义
可以用宏判断是否为ARC环境 #if _has_feature(objc_arc) #else //MRC #endif C中的预编译宏定义 -- 作者: infobillows 来源:网络 在将一 ...
- C/C++中的预编译指令
工作中遇到的: 一个头文件中的: #pragma warning(disable:4996)#pragma warning(disable:4244)#pragma warning(disable:4 ...
- C#中的预编译指令介绍
原文:C#中的预编译指令介绍 1.#define和#undef 用法: #define DEBUG #undef DEBUG #define告诉编译器,我定义了一个DEBUG的一个符号,他类似一个变量 ...
- 在VisualGDB中配置预编译头加快编译速度
今天是中秋佳节,但是写完已经是第二天凌晨了,还是祝大家中秋快乐! VS对C++的支持相较GCC太弱了,连续几个VS版本对C++的改进都很小.很少.对Cpper也许是一种痛,我们也许希望能使用VS的强大 ...
- js中的预编译
预编译 js执行顺序: 词法/语法分析 预编译 解释执行 js中存在预编译 function demo() { console.log('I am demo'); } demo(); //I am d ...
- javascript中的预编译问题
Js作为脚本语言,可以不需要编译直接运行,但遇到类似变量或者函数同名,预编译方面的知识可以帮助我们更好解决问题. 示例: 这是一段js中普通的函数调用代码 <script>1. // ...
- 怎么向Xcode6 IOS8之后向项目中添加预编译文件
苹果的XCode在6版本之后新建项目时取消了自动创建预编译头文件pch,该文件里存放的工程中一些不常被修改的代码,比如常用的框架头文件,这样做的目的提高编译器编译速度.我们可以往里面加入一些项目中都要 ...
随机推荐
- 吴恩达深度学习:2.16关于python/numpy
- vue与angular 区别
1.vue的双向数据绑定是基于 Es5中的getter和setter来实现的,而angular而是由自己实现的一套模板编译规则,需要进行 ‘脏’ 检查,vue则不需要,因此,vue性能上更高一些,但是 ...
- ping命令的七种用法
能不能讲下ping命令的使用,其实对于命令的使用我们之前提到过一些,但对ping命令没有过多讲解,一般我们用的都是它的基本功能,今天我们来详细看下ping命令详细使用. 一.ping基本使用详解 在网 ...
- python多线程之threading、ThreadPoolExecutor.map
背景: 某个应用场景需要从数据库中取出几十万的数据时,需要对每个数据进行相应的操作.逐个数据处理过慢,于是考虑对数据进行分段线程处理: 方法一:使用threading模块 代码: # -*- codi ...
- 一、Linux平台部署ASP.NET、ASP.NET CORE、PHP
一.什么是Jexus Jexus是一款Linux平台上的高性能WEB服务器和负载均衡网关服务器,以支持ASP.NET.ASP.NET CORE.PHP为特色,同时具备反向代理.入侵检测等重要功能.可以 ...
- win10将mongodb加入系统服务,官方源码报错问题记录
进入C:\Program Files\MongoDB\Server\3.6目录下 1.编写配置文件mongodb.cfg: dbpath=D:\MongoDB\data\db #数据库路径 logpa ...
- DP+滚动数组 || [Usaco2007 Nov]Telephone Wire 架设电话线 || BZOJ 1705 || Luogu P2885
本来是懒得写题解的…想想还是要勤发题解和学习笔记…然后就滚过来写题解了. 题面:[USACO07NOV]电话线Telephone Wire 题解: F[ i ][ j ] 表示前 i 根电线杆,第 i ...
- Angular7和PrimeNg集成
常规操作之后,随便加了一个控件发现报错了.错误信息看起来是不能识别PrimeNg的组件,经过一番折腾发现.因为用到了ngModel,需要导入FormsModule.因为新建的工程没有导入,导入之后就好 ...
- 一个web应用的诞生(3)
经过上一章的内容,其实就页面层来说已结可以很轻松的实现功能了,但是很明显美观上还有很大的欠缺,现在有一些很好的前端css框架,如AmazeUI,腾讯的WeUI等等,这里推荐一个和flask集成很好的b ...
- java 乱码
https://blog.csdn.net/qq_27545063/article/details/81138722 https://blog.csdn.net/dachaoa/article/det ...