pau*_*doo 30 xslt optimization profiling
我有一个XSLT用于在浏览器中查看XML文件.XSLT是天真的编写,目前需要很长时间才能执行(几分钟).
我的XML文件大小适中(~1 MiB),而执行不同处理的同一文档的其他XSLT执行速度要快得多.所以我知道问题不在于XML的大小,而是我的XSLT.
如何进行性能分析和优化我的XSLT?
(在浏览器中执行复杂的XSLT是一个坏主意吗?我应该改为应用XSLT应用程序吗?)
Dir*_*mar 31
您使用的是哪个XSLT引擎?如果您使用的是.NET引擎和Visual Studio,则可以使用集成到Visual Studio中的XSLT分析器,这是非常有用的.
其他出色的性能分析工具是Altova的XML Spy和Oxygen.
如果您要发布XSLT,那么告诉您哪里可能存在瓶颈会更容易.一般要小心使用XPath表达式,例如'//',前面的::*和下面的::*.更多规则和最佳实践:
- 避免重复使用
"//item".- 不要多次评估相同的节点集; 将其保存在变量中.
<xsl:number>如果可以,请避免.例如,通过使用position().- 使用
<xsl:key>,例如解决问题的分组.- 避免模板规则中的复杂模式.相反,在规则中使用.
- 使用
preceding[-sibling]或following[-sibling]轴时要小心.这通常表示具有n平方性能的算法.- 不要多次对同一节点集进行排序.如有必要,将其保存为结果树片段并使用
node-set()扩展功能访问它.- 要输出简单
#PCDATA元素 的文本值,请<xsl:value-of>优先使用<xsl:apply-templates>.
遵循这些规则通常会产生非常高效的XSLT,您可能根本不需要使用分析器.
关于你关于XSLT的问题在浏览器中:我不会推荐它,因为第一你是不是独立于平台(不是每一个浏览器可能支持或某些浏览器可能只用一个业绩不佳的引擎支持它)和第二,你无法控制发动机使用.
Dim*_*hev 22
如果您提供XSLT代码和您观察到问题的XML文档,我和其他人可以尝试提供帮助.
下面是一些XSLT的使用率和性能的技巧从迈克尔·凯:
有关如何有效使用XSLT的八个技巧:
如何编写高效X SLT的八个技巧:
//item".<xsl:number>如果可以,请避免.例如,通过使用position().<xsl:key>,例如解决问题的分组.<xsl:choose>在规则中使用.preceding[-sibling]或following[-sibling]
轴时要小心.这通常表示具有n相同性能的算法.node-set()扩展功能访问它.<xsl:value-of>
优先使用<xsl:apply-templates>.