CDATA - (未解析)字符数据
术语 CDATA 是不应该由 XML 解析器解析的文本数据。
像 "<" 和 "&" 字符在 XML 元素中都是非法的。
"<" 会产生错误,因为解析器会把该字符解释为新元素的开始。
"&" 会产生错误,因为解析器会把该字符解释为字符实体的开始。
某些文本,比如 JavaScript 代码,包含大量 "<" 或 "&" 字符。为了避免错误,可以将脚本代码定义为 CDATA。
CDATA 部分中的所有内容都会被解析器忽略。
CDATA 部分由 "<![CDATA[" 开始,由 "]]>" 结束:

<script>
<![CDATA[
function matchwo(a,b)
{
if (a < b && a < 0) then
{
return 1;
}
else
{
return 0;
}
}
]]>
</script>


在上面的实例中,解析器会忽略 CDATA 部分中的所有内容。
关于 CDATA 部分的注释:
CDATA 部分不能包含字符串 "]]>"。也不允许嵌套的 CDATA 部分。
标记 CDATA 部分结尾的 "]]>" 不能包含空格或换行。

说明:

XML 文档中的所有文本均会被解析器解析。


只有 CDATA 区段中的文本会被解析器忽略。

在xml文件中,若某个标签内容包含特殊字符,如"<"、"&"等,他们在xml元素中都是非法的,为了避免错误,可以将这些符号放在<![CDATA[...]]>标签中,这样xml就不会对其解析,避免错误。

CDATA的基本语法:

<![CDATA[

内容...

]]>

实例:

<介绍><![CDATA[$^&()><LKL:>Kjlk><]]></介绍>

<头像><![CDATA[$%()^&#@@]]></头像>


面试题: 请问如何使用xml文件来传递、保存一个图片.

答: 使用程序先读入到内存,然后保存到 xml 文件的<![CDATA[ 文件内容]]> 中