在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,该文件里存放的工程中一些不常被修改的代码,比如常用的框架头文件,这样做的目的提高编译器编译速度.我们可以往里面加入一些项目中都要 ...
随机推荐
- 关于android studio从2.3升级到3.0以上可能会遇到的问题
请参考链接: http://blog.csdn.net/hylczp/article/details/60137958 gradle-3.3-all网盘下载地址: 链接:http://pan.baid ...
- Delphi 逻辑运算符与布尔表达式
- Noip2018退役记。
下面是边考试边写的严肃版退役记\(:D\) Day0 其实我本来想取个这个名字:\(NOIP2018\)提高组复赛试题解析 但是这个博客自己求生欲望太强自己改名了. 先占个坑. noip考前毒奶 \( ...
- SpringMVC初识
1 SpringMVC的概述 Spring为展现层提供的基于MVC设计理念的优秀的web框架,是目前最主流的MVC框架之一. Spring3.0后面全面超过Struts2,成为了最优秀的MVC框架. ...
- javaScript中的 this
普通函数中的 this // es3中 function foo() { console.log(this);// 这里的this是 window } foo(); // 在es5中 严格模式下 fu ...
- 两句话掌握 Python 最难知识点——元类
千万不要被所谓“元类是99%的python程序员不会用到的特性”这类的说辞吓住.因为每个中国人,都是天生的元类使用者 学懂元类,你只需要知道两句话: 道生一,一生二,二生三,三生万物 我是谁?我从哪来 ...
- Linux设置程序开机自启动
注意: 作者测试时,Linux版本为RedHat6,同时应用在CentOS6应该也可以(作者未实测,但有同事在CentOS6上使用可行),系统版本的不同,可能造成操作上的差异(CentOS7就与Cen ...
- SQL基础测试
SQL 测验 结果:20/20 您的回答: 1.SQL 指的是? 您的回答:Structured Query Language 2.哪个 SQL 语句用于从数据库中提取数据? 您的回答:SELECT ...
- java总结2
1,对象数组,必须指定了数组长度,长度是固定的 2,除了ArrayList<E>以外,类赋值给变量,只有string类拿到的是值,其他类拿到的都是类的地址值, ArrayList<E ...
- JPA学习(三、JPA_API)
框架学习之JPA(三) JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中 ...