XML和JSON数据格式对比
概念
XML
扩展标记语言 (Extensible Markup Language, XML) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言。 XML使用DTD(document type definition)文档类型定义来组织数据;格式统一,跨平台和语言,早已成为业界公认的标准。
XML是标准通用标记语言 (SGML) 的子集,非常适合 Web 传输。XML 提供统一的方法来描述和交换独立于应用程序或供应商的结构化数据。
http://www.cnblogs.com/SanMaoSpace/p/3139186.html
XML规范:
https://www.w3.org/TR/REC-xml/
例子.
XML数据格式样例:
<employees>
<employee>
<firstName>Bill</firstName>
<lastName>Gates</lastName>
</employee>
<employee>
<firstName>George</firstName>
<lastName>Bush</lastName>
</employee>
<employee>
<firstName>Thomas</firstName>
<lastName>Thomas</lastName>
</employee>
</employees>
JSON
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,是理想的数据交换格式。同时,JSON是 JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON数据不须要任何特殊的 API 或工具包。
http://www.cnblogs.com/worfdream/articles/1956449.html
JSON规范:
http://json.org/
例子.
JSON数据格式样例:
{
"employees": [
{
"firstName": "Bill",
"lastName": "Gates"
},
{
"firstName": "George",
"lastName": "Bush"
},
{
"firstName": "Thomas",
"lastName": "Carter"
}
]
}
对比
效率实验对比
以概念章节中JSON的例子数据为研究对象, 构造同等的XML数据:
以这两个数据考察,它们分别在相同浏览器中的解析时间,和 查询时间:
在firefox浏览器中:
1、 解析1000次;
2、 查询第二个员工lastName,10000次。
针对两个数据分别构造页面脚本,分别跑5次,实验结果如下:
XML
|
项目 次数 |
1 |
2 |
3 |
4 |
5 |
平均 |
|
解析 |
1646 |
1656 |
1608 |
1650 |
1661 |
1644.2 |
|
查找 |
10 |
10 |
10 |
11 |
11 |
10.4 |
单位(ms)
JSON
|
项目 次数 |
1 |
2 |
3 |
4 |
5 |
平均 |
|
解析 |
4 |
4 |
3 |
3 |
3 |
3.4 |
|
查找 |
1 |
1 |
1 |
1 |
0 |
0.8 |
单位(ms)
总结,JSON的效率远远高于xml,解析效率是xml的484倍,查找效率是13倍。
数据量对比
调查对于同一份数据信息,使用XML描述和JSON描述数据量差别对比。
以效率实验中的数据为对象,统计结果:XML是JSON的1.71倍。
XML: 263Byte
JSON: 154Byte
JSON对于相同信息的描述,比XML更加省数据量,比XML省42%,传输更快。
特性对比
|
XML |
JSON |
|
|
可读性 |
高 |
高 |
|
可扩展性 |
高 |
高 |
|
编写容易度 |
中 |
高 |
|
查找容易度 |
低 |
高 |
|
流行度 |
高 |
中 |
|
数据描述能力 |
高 |
中 |
|
安全性 |
高 |
中 |
说明:
1、 关于流行度,XML已经被业界广泛的使用,而JSON才刚刚开始,但是在Ajax这个特定的领域,未来的发展一定是XML让位于JSON。到时Ajax应该变成Ajaj(Asynchronous Javascript and JSON)了。
2、 关于安全性,由于大部分Javascript库都是使用eval()来解析数据,存在执行恶意JSON数据的安全漏洞;当然可以使用专门的JSON解析器来避免这个问题。相比,XML更安全一些。
参考:
https://blog.tanteng.me/2012/09/json-xml-compare/
http://www.cnblogs.com/SanMaoSpace/p/3139186.html
综上所述,XML由于其诞生时间早,相对成熟,在流行度、数据描述能力、安全性相对较高,其它特性JSON较高或者相同。其中编写和查询容易度,关系到开发体验,能提高开发效率,JSON优于XML。
效率实验
json
<!doctype html>
<html>
<head>
</head>
<body> <script type="text/javascript">
function hereDoc(f){
return f.toString().replace(/^[^\/]+\/\*!?\s?/, '').replace(/\*\/[^\/]+$/, '');
} var jsonstring = hereDoc(function(){/*
{
"employees": [
{
"firstName": "Bill",
"lastName": "Gates"
},
{
"firstName": "George",
"lastName": "Bush"
},
{
"firstName": "Thomas",
"lastName": "Carter"
}
]
}
*/}); // 统计解析耗时
var starttime = (new Date()).getTime();
for (var i = 0; i < 1000; i++) {
JSON.parse(jsonstring);
};
var endtime = (new Date()).getTime();
console.log("parsing consume time ="+(endtime - starttime)) // 查询第二个成员lastName
var starttime = (new Date()).getTime();
var jsonObj = JSON.parse(jsonstring);
//console.log("lastName = "+lastName)
for (var i = 0; i < 10000; i++) {
var lastName = jsonObj.employees[1].lastName
};
var endtime = (new Date()).getTime();
console.log("finding consume time ="+(endtime - starttime)) </script> </body>
</html>
xml
<!doctype html>
<html>
<head>
</head>
<body> <script type="text/javascript">
function hereDoc(f){
return f.toString().replace(/^[^\/]+\/\*!?\s?/, '').replace(/\*\/[^\/]+$/, '');
} function GetXMLParseFunc() {
if (window.DOMParser)
{
var parser=new DOMParser();
return function (xmlstring) {
return parser.parseFromString(xmlstring,"text/xml");
}
}
else // Internet Explorer
{
console.log("not support DOMParser");
// xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
// xmlDoc.async="false";
// xmlDoc.loadXML(txt);
}
} var xmlstring = hereDoc(function(){/*
<employees>
<employee>
<firstName>Bill</firstName>
<lastName>Gates</lastName>
</employee>
<employee>
<firstName>George</firstName>
<lastName>Bush</lastName>
</employee>
<employee>
<firstName>Thomas</firstName>
<lastName>Thomas</lastName>
</employee>
</employees>
*/}); var parseFunc = GetXMLParseFunc(); // 统计解析耗时
var starttime = (new Date()).getTime();
for (var i = 0; i < 1000; i++) {
parseFunc(xmlstring);
};
var endtime = (new Date()).getTime();
console.log("parsing consume time ="+(endtime - starttime)) // 查询第二个成员lastName
var starttime = (new Date()).getTime();
var xmlObj = parseFunc(xmlstring);
for (var i = 0; i < 10000; i++) {
var lastName = xmlObj.getElementsByTagName("employee")[1].getElementsByTagName("lastName")[0].childNodes[0].nodeValue
//console.log("lastName = "+lastName)
};
var endtime = (new Date()).getTime();
console.log("finding consume time ="+(endtime - starttime)) </script> </body>
</html>
XML和JSON数据格式对比的更多相关文章
- XML与JSON的对比
XML与JSON的对比 1.各自定义 XML 扩展标记语言 (Extensible Markup Language, XML) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据.定义数据类 ...
- xml 和json 数据格式及解析
来源:http://blog.jobbole.com/79252/ 引言 NOKIA 有句著名的广告语:“科技以人为本”.任何技术都是为了满足人的生产生活需要而产生的.具体到小小的一个手机,里面蕴含的 ...
- XML和JSON数据格式
目录 XML DTD(文档类型定义) DTD实体 JSON 使用python解析JSON数据 XML和JSON的区别 XML的优缺点 JSON的优缺点 XML和JSON都是web存储和传输过程中数据的 ...
- XML和JSON的对比
简介: 客户端和服务器之间进行数据交互时,服务器往往会返回给客户端一定格式的数据.一般而言,服务器返回给客户端的数据为JSON或者XML文档格式的数据(文件下载除外).下面就针对于这两种数据格式分别介 ...
- xml和json的区别
本文转自SanMaoSpace的博客 链接地址如下:http://www.cnblogs.com/SanMaoSpace/p/3139186.html 1.定义介绍 (1).XML定义扩展标记语言 ( ...
- 全面剖析XML和JSON
1.定义介绍 (1).XML定义扩展标记语言 (Extensible Markup Language, XML) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据.定义数据类型,是一种允许 ...
- 用xml还是json
1.定义介绍 (1).XML定义 扩展标记语言 (Extensible Markup Language, XML) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据.定义数据类型,是一种允 ...
- [Android]XML和JSON的区别
1.定义介绍 (1).XML定义 扩展标记语言 (Extensible Markup Language, XML) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据.定义数据类型,是一种允 ...
- 浅析XML和JSON的区别
前言 今天做接口对接时,发现对方竟然是通过XML进行数据传输,当时冒出的第一个想法就是:WTF,这都什么年代了,还在用XML,是来搞笑的吧,JSON它不香吗? 想法归想法,但对接还是要完成的是吧?然后 ...
随机推荐
- java 猜数字游戏
作用:猜数字游戏.随机产生1个数字(1~10),大了.小了或者成功后给出提示. 语言:java 工具:eclipse 作者:潇洒鸿图 时间:2016.11.10 >>>>> ...
- 【填坑向】spoj COT/bzoj2588 Count on a tree
这题是学主席树的时候就想写的,,, 但是当时没写(懒) 现在来填坑 = =日常调半天lca(考虑以后背板) 主席树还是蛮好写的,但是代码出现重复,不太好,导致调试的时候心里没底(虽然事实证明主席树部分 ...
- AngularJS 30分钟快速入门【译】
引用自:http://www.revillweb.com/tutorials/angularjs-in-30-minutes-angularjs-tutorial/,翻译如下: 简介 我三年前开始使用 ...
- Java 异常java.lang.IllegalArgumentException: Illegal group reference
当字符串方法replaceAll()中替换字符含有特殊字符$如, String test = "<StreamingNo>abc</StreamingNo>" ...
- java和js根据一个或者多个空格截取字符串
java: String str = "张三 fw1234"; String s[] = str.split("\\s+"); js: var str=&quo ...
- linux 关于session缓存丢失,自己掉坑里面了
突然间session失效了,死活打不上缓存.顺着解决思路:程序--再检查程序--文件权限--查看服务器配置 我只想说一句,我操.尼玛,各种调试,各种自虐.毫无意义,三个钟头流失. 看看几点了,快凌晨两 ...
- 使用MS Test进行单元测试
MS Test也可以方便的进行单元测试,可以通过Visual Studio很方便的建立单元测试. 添加对待测试工程的引用,即可方便的开始单元测试. 最基本的一些测试使用如下: using System ...
- bzoj 3438: 小M的作物
Description 背景 小M还是个特么喜欢玩MC的孩纸... 描述 小M在MC里开辟了两块巨大的耕地A和B(你可以认为容量是无穷),现在,小P有n中作物的种子,每种作物的种子有1个(就是可以种一 ...
- php获得http头部信息的方法
$url = 'http://www.baidu.com'; $fp = fopen($url, 'r'); $meta_data = stream_get_meta_data($fp); var_d ...
- AOP学习心得&jdk动态代理与cglib比较
什么是AOP AOP(Aspect-OrientedProgramming,面向方面编程),可以说是OOP(Object-Oriented Programing,面向对象编程)的补充和完善.OOP引入 ...