在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,该文件里存放的工程中一些不常被修改的代码,比如常用的框架头文件,这样做的目的提高编译器编译速度.我们可以往里面加入一些项目中都要 ...
随机推荐
- Java Blob类型和String类型相互转换
1.String 转 Blob: String content = "Hello World!"; Blob blob = Hibernate.createBlob(content ...
- flutter-dart语言初识
dart 官方文档 http://dart.goodev.org/guides/language/language-tour# 重要概念所以能够使用变量引用的都是对象,也就是所以可以赋值给变量的都是对 ...
- 破解phpStorm 2018 亲测
网上教程很多,这里我就不多赘述,我也是看其他教程试过来的. 下面分步骤介绍一下: 1.下载,我这里选用的版本是 phpStorm 2018.3 ,下载地址 https://www.newasp.net ...
- final修饰符—不可变
final 修饰符 修饰类 不可以有子类 修饰变量 变量一旦获得初始值就不可改变,不能被重新赋值 成员变量:初始值必须有程序员显式设置,系统不会对其隐式初始化 类变量:静态初始化块 | 声明该类变量时 ...
- 性能测试:oprofile的学习使用
一.oprofile简介 Oprofile是linux上的性能监测工具,有人说是性能测试的神器.通过CPU硬件提供的性能计数器对事件进行采样,从代码层面分析程序的性能消耗情况,找出程序性能的问题点. ...
- LNMP 多版本PHP同时运行
首先需要装好两个版本以上的PHP(例如:php5.6和php7两个版本).这里假设你已安装完成.1.配置并启动php默认版本: (设置 nginx 的 vhost 域名配置文件监听端口就好) 1).打 ...
- ps雨滴效果制作
雨滴效果制作 尽量选择比较暗或者有人打伞的照片,方便制作雨天的效果 新建图层,设置前景色为黑色,并填充新建的图层为黑色 选择滤镜->杂色->添加杂色,数量设置为150左右(设置得越大后面的 ...
- C语言字符串追加,双色球等案例
//C语言中没有字符串概念,有的只是字符型数组,以str1[]的值为例,该字符数组的长度为11--->包含了字母,空格,以及结束字符'\0'(斜杠0)//基于上述原因,读取一个字符型数组的有效方 ...
- 动态树(Link-Cut-Tree)简单总结(指针版本)
Link-Cut-Tree(动态树 LCT) 1.定义 1. 偏爱子节点: 一颗子树内最后访问的点若在该子树根节点 X 的某个儿子节点 P 的子树中,则称 P 为 X 的偏爱子节点. 偏爱边:连向偏爱 ...
- Docker(2)--Centos7 上安装部署
Centos7 上安装docker Docker从1.13版本之后采用时间线的方式作为版本号,分为社区版CE和企业版EE. 社区版是免费提供给个人开发者和小型团体使用的,企业版会提供额外的收费服务,比 ...