By CaesarChang               

~关注我  带你看更多精品技术和面试必备

XML(既可以保存在文件中 ,又可以在内存中构建)

可扩展标记语言(eXtensible Markup Language)。

xml特点:

1xml具有平台无关性, 是一门独立的标记语言.

2. xml具有自我描述性

可以用于:

1. 网络数据传输.  (少)

2. 数据存储    (少)

3. 配置文件  (主要用于此)

格式:

1. XML文档声明

<?xml version="1.0" encoding="UTF-8"?>

2 标记 ( 元素 / 标签 / 节点)

例:

<names>

  <name>张三</name>

  <name> 李四</name>

</names>

 特点:

1 标记名称 允许重复

2标记除了开始和结束 , 还有属性.  <person  id="1">   </person>

3注释不能写在文档文档声明前, 注释不能嵌套注释

4 一个XML文档中, 必须有且且仅允许有一个根标记.

5 .名称可以含字母、数字以及其他的字符 ,名称不能以数字或者标点符号或者"xml"开始

6 不想被解析的用  " < ! [ C D A T A [ "  不想解析的东西 " ] ] > " 

 

 面试题:

 Java中有几种XML解析方式 ? 分别是什么 ? 有什么样的优缺点 ?

1 SAX解析

 解析方式是事件驱动机制

逐行读取XML文件解析 , 每当解析到一个标签的开始/结束/内容/属性时,触 发事件.

缺点:

1单向解析,无法定位文档层次,无法同时访问同一文档的不同部分数据(因为逐 行解析, 当解析第n行是, 第n-1行已经被释放了, 无法在进行操作了).

2. 无法得知事件发生时元素的层次, 只能自己维护节点的父/子关系.

3. 只读解析方式, 无法修改XML文档的内容.

优点:

1 分析能够立即开始,而不是等待所有的数据被处理 逐行加载,节省内存.

2 有助于解析大于系统内存的文档 有时不必解析整个文档,它可以在某个条件得到满足时停止解析.

2.  DOM解析

分析该结构通常需要加载整个 文档和内存中建立文档树模型.程序员可以通过操作文档树, 来完成数据的获取 修改 删除等.

优点:

文档在内存中加载, 允许对数据和结构做出更改.

访问是双向的,可以在任何时候在树中双向解析数据。

缺点:

文档全部加载在内存中 , 消耗资源大.

3. JDOM解析

目的是成为Java特定文档模型,它简化与XML的交互并且比使用DOM实现更快。

优点:

1 使用具体类而不是接口,简化了DOM的API。

2 大量使用了Java集合类,方便了Java开发人员。

缺点:

Element 没有较好的灵活性。

性能不是那么优异。

4. DOM4J解析

它是JDOM的一种智能分支。它合并了许多超出基本XML文档表示的功能,包括集成的XPath 支持、XML Schema支持以及用于大文档或流化文档的基于事件的处理。它还提供了构建文档表示的选项,

DOM4J解析XML 掌握

1 引入jar文件 dom4j.jar

2. 创建一个指向XML文件的输入流

FileInputStream fis = new FileInputStream("xml文件的地址");

3. 创建一个XML读取工具对象

SAXReader sr = new SAXReader();

4. 使用读取工具对象, 读取XML文档的输入流 , 并得到文档对象

Document doc = sr.read(fis);

5. 通过文档对象, 获取XML文档中的根元素对象

Element root = doc.getRootElement();

文档对象 Document

指的是加载到内存的 整个XML文档.

常用方法:

1. 通过文档对象, 获取XML文档中的根元素对象

Element root = doc.getRootElement();

2. 添加根节点

Element root = doc.addElement("根节点名称");

元素对象 Element

指的是XML文档中的单个节点.

常用方法:

1. 获取节点名称

String getName();

2. 获取节点内容

String getText();

3. 设置节点内容

String setText();

4. 根据子节点的名称 , 获取匹配名称的第一个子节点对象.

Element element(String 子节点名称);

5. 获取所有的子节点对象

List elements();

6. 获取节点的属性值

String attributeValue(String 属性名称);

7. 获取子节点的内容

String elementText(String 子节点名称);

8. 添加子节点

Element addElement(String 子节点名称);

9. 添加属性

void addAttribute(String 属性名,String 属性值);

DOM4J - XPATH解析XML

1. / : 从根节点开始查找

2. // : 从发起查找的节点位置 查找后代节点 

3.   . : 查找当前节点

4.   . .    : 查找父节点

5.  @:  选择属性. 

属性使用方式:     [@属性名='值']      [@属性名>'值']    [@属性名<'值']    [@属性名!='值']

举例:

//book[@id='1']//name

XML与JSON(最全 最精美 )_子节点

Java生成XML 熟悉

XStream 的使用 了解

快速的将Java中的对象, 转换为 XML字符串.

使用步骤: 

1. 创建XStream 对象

XStream x = new XStream();

[2].修改类生成的节点名称 ( 默认节点名称为 包名.类名 )

x.alias("节点名称",类名.class);

3. 传入对象 , 生成XML字符串

String xml字符串 = x.toXML(对象);

案例:

: Person p = new Person(1001, "张三", "不详");

XStream x = new XStream();

x.alias("haha", Person.class);

String xml = x.toXML(p);

System.out.println(xml);

JSON

JSON: JavaScript Object Notation JS对象简谱 , 是一种轻量级的数据交换格式.
JSON:
{ 
"name":"金苹果", 
"info":"种苹果" 
}
1   键与值之间使用冒号连接, 多个键值对之间使用逗号分隔.
2    键值对的键 应使用引号引住
3 数组格式可以与对象嵌套     例如:
{ 
"pengyou":["张三","李四",{
"name": "王五",
"info":"很吊"
}]
}
可以实现
将Java中的对象 快速的转换为 JSON格式的字符串. 
将JSON格式的字符串, 转换为Java的对象
Gson



XML与JSON(最全 最精美 )_xml_02

FastJson

XML与JSON(最全 最精美 )_子节点_03

XML与JSON(最全 最精美 )_XML_04

 

       一般采用阿里的fastJson  如果除了漏洞,就使用谷歌的Gson