XslCompiledTransform性能优化核心是“编译一次、输入流式、输出直写”:预编译模板并复用实例,用XmlReader流式输入,XmlWriter直写目标流,禁用调试、格式化和DTD处理。

XslCompiledTransform 是 .NET 中用于高效执行 XSLT 1.0 转换的核心类,替代了已过时的 XslTransform。它默认启用编译、支持 XSLT 参数、输出设置灵活,且线程安全(实例可复用)。但“能用”不等于“用好”,尤其在高频、大数据量场景下,性能差异明显。
预编译 XSLT 模板,避免重复解析
每次调用 Load() 解析 XSL 文件或字符串都会触发语法检查、AST 构建和 JIT 编译,开销不小。关键原则:**一份样式表,一次编译,多次执行**。
- 将
XslCompiledTransform实例作为静态字段或依赖注入单例(注意:它本身是线程安全的) - 使用
Load(XmlReader)或Load(string)预加载并编译,不要在每次转换时重新 Load - 若 XSL 来自数据库或远程配置,加一层缓存(如
ConcurrentDictionary),以 URI 或哈希为 key
输入 XML 尽量用 XmlReader,避免加载整个 XmlDocument
Transform(XmlReader, XmlWriter) 是最轻量的入口。相比传入 XmlDocument 或 XDocument,它不构建内存 DOM 树,适合大文件或流式处理。
- 用
XmlReader.Create(stream, settings)控制解析行为(如禁用 DTD、关闭命名空间检查) - 设置
XmlReaderSettings.DtdProcessing = DtdProcessing.Ignore防止外部实体攻击和解析延迟 - 避免把 XML 先读成字符串再用
StringReader—— 这仍会多一次字符解码,直接传Stream更优
输出端优化:用 XmlWriter + 适当设置
输出目标影响性能和内存占用。推荐组合:XmlWriter + XmlWriterSettings + 流式目标(如 MemoryStream 或 HttpResponse.Body)。
- 禁用格式化:
settings.Indent = false(除非调试需要) - 指定编码(如 UTF-8)并设
settings.Encoding = Encoding.UTF8,避免自动探测 - 对 Web 输出,直接写入响应流:
transform.Transform(inputReader, XmlWriter.Create(context.Response.Body, settings)) - 避免用
StringBuilder接收结果后再转字符串 —— 多一次拷贝;改用MemoryStream+ToArray()或直接流式返回
其他关键细节
小调整常带来可观收益:
- 禁用调试信息:
settings.Debug = false(发布环境默认即关,但显式设更稳妥) - 慎用
存大量节点集 —— 它会强制求值并缓存,可能吃光内存;改用或流式匹配 - XSLT 中避免
//深度遍历,优先用明确路径(如/root/item)或key()函数加速查找 - 如需多次不同参数转换同一输入,先用
XmlReader读一次,再克隆(reader.ReadSubtree())供多次复用
基本上就这些。核心就三点:编译一次、输入流式、输出直写。不复杂但容易忽略。
