[java] view plain copy print ?
-
/** Dom方式,创建 XML */
-
public String domCreateXML() {
-
String xmlWriter = null;
-
Person []persons = new Person[3]; // 创建节点Person对象
-
persons[0] = new Person(1, “sunboy_2050”, “http://blog.csdn.net/sunboy_2050”);
-
persons[1] = new Person(2, “baidu”, “http://www.baidu.com”);
-
persons[2] = new Person(3, “google”, “http://www.google.com”);
-
try {
-
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
-
DocumentBuilder builder = factory.newDocumentBuilder();
-
Document doc = builder.newDocument();
-
Element eleRoot = doc.createElement(“root”);
-
eleRoot.setAttribute(“author”, “homer”);
-
eleRoot.setAttribute(“date”, “2012-04-26”);
-
doc.appendChild(eleRoot);
-
int personsLen = persons.length;
-
for(int i=0; i<personsLen; i++) {
-
Element elePerson = doc.createElement(“person”);
-
eleRoot.appendChild(elePerson);
-
Element eleId = doc.createElement(“id”);
-
Node nodeId = doc.createTextNode(persons[i].getId() + “”);
-
eleId.appendChild(nodeId);
-
elePerson.appendChild(eleId);
-
Element eleName = doc.createElement(“name”);
-
Node nodeName = doc.createTextNode(persons[i].getName());
-
eleName.appendChild(nodeName);
-
elePerson.appendChild(eleName);
-
Element eleBlog = doc.createElement(“blog”);
-
Node nodeBlog = doc.createTextNode(persons[i].getBlog());
-
eleBlog.appendChild(nodeBlog);
-
elePerson.appendChild(eleBlog);
-
}
-
Properties properties = new Properties();
-
properties.setProperty(OutputKeys.INDENT, “yes”);
-
properties.setProperty(OutputKeys.MEDIA_TYPE, “xml”);
-
properties.setProperty(OutputKeys.VERSION, “1.0”);
-
properties.setProperty(OutputKeys.ENCODING, “utf-8”);
-
properties.setProperty(OutputKeys.METHOD, “xml”);
-
properties.setProperty(OutputKeys.OMIT_XML_DECLARATION, “yes”);
-
TransformerFactory transformerFactory = TransformerFactory.newInstance();
-
Transformer transformer = transformerFactory.newTransformer();
-
transformer.setOutputProperties(properties);
-
DOMSource domSource = new DOMSource(doc.getDocumentElement());
-
OutputStream output = new ByteArrayOutputStream();
-
StreamResult result = new StreamResult(output);
-
transformer.transform(domSource, result);
-
xmlWriter = output.toString();
-
} catch (ParserConfigurationException e) { // factory.newDocumentBuilder
-
e.printStackTrace();
-
} catch (DOMException e) { // doc.createElement
-
e.printStackTrace();
-
} catch (TransformerFactoryConfigurationError e) { // TransformerFactory.newInstance
-
e.printStackTrace();
-
} catch (TransformerConfigurationException e) { // transformerFactory.newTransformer
-
e.printStackTrace();
-
} catch (TransformerException e) { // transformer.transform
-
e.printStackTrace();
-
} catch (Exception e) {
-
e.printStackTrace();
-
}
-
savedXML(fileName, xmlWriter.toString());
-
return xmlWriter.toString();
-
}
运行结果:
3、Dom 解析 XML
Dom方式,解析XML是创建XML的逆过程,主要用到了builder.parse(is)进行解析,然后通过Tag、NodeList、Element、childNotes等得到Element和Node属性或值。
Code
[java] view plain copy print ?
-
/** Dom方式,解析 XML */
-
public String domResolveXML() {
-
StringWriter xmlWriter = new StringWriter();
-
InputStream is= readXML(fileName);
-
try {
-
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
-
DocumentBuilder builder = factory.newDocumentBuilder();
-
Document doc = builder.parse(is);
-
doc.getDocumentElement().normalize();
-
NodeList nlRoot = doc.getElementsByTagName(“root”);
-
Element eleRoot = (Element)nlRoot.item(0);
-
String attrAuthor = eleRoot.getAttribute(“author”);
-
String attrDate = eleRoot.getAttribute(“date”);
-
xmlWriter.append(“root”).append(“\t\t”);
-
xmlWriter.append(attrAuthor).append(“\t”);
-
xmlWriter.append(attrDate).append(“\n”);
-
NodeList nlPerson = eleRoot.getElementsByTagName(“person”);
-
int personsLen = nlPerson.getLength();
-
Person []persons = new Person[personsLen];
-
for(int i=0; i<personsLen; i++) {
-
Element elePerson = (Element) nlPerson.item(i); // person节点
-
Person person = new Person(); // 创建Person对象
-
NodeList nlId = elePerson.getElementsByTagName(“id”);
-
Element eleId = (Element)nlId.item(0);
-
String id = eleId.getChildNodes().item(0).getNodeValue();
-
person.setId(Integer.parseInt(id));
-
NodeList nlName = elePerson.getElementsByTagName(“name”);
-
Element eleName = (Element)nlName.item(0);
-
String name = eleName.getChildNodes().item(0).getNodeValue();
-
person.setName(name);
-
NodeList nlBlog = elePerson.getElementsByTagName(“blog”);
-
Element eleBlog = (Element)nlBlog.item(0);
-
String blog = eleBlog.getChildNodes().item(0).getNodeValue();
-
person.setBlog(blog);
-
xmlWriter.append(person.toString()).append(“\n”);
-
persons[i] = person;
-
}
-
} catch (ParserConfigurationException e) { // factory.newDocumentBuilder
-
e.printStackTrace();
-
} catch (SAXException e) { // builder.parse
-
e.printStackTrace();
-
} catch (IOException e) { // builder.parse
-
e.printStackTrace();
-
} catch (Exception e) {
-
e.printStackTrace();
-
}
-
return xmlWriter.toString();
-
}
运行结果:
4、Person类
Person类,是创建xml的单位实例,基于Java面向对象定义的一个类
[java] view plain copy print ?
-
public class Person {
-
private int id;
-
private String name;
-
private String blog;
-
public Person() {
-
this.id = -1;
-
this.name = “”;
-
this.blog = “”;
-
}
-
public Person(int id, String name, String blog) {
-
this.id = id;
-
this.name = name;
-
this.blog = blog;
-
}
-
public Person(Person person) {
-
this.id = person.id;
-
this.name = person.name;
-
this.blog = person.blog;
最后
其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。
上面分享的腾讯、头条、阿里、美团、字节跳动等公司2019-2021年的高频面试题,博主还把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。
【Android思维脑图(技能树)】
知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。
【Android高级架构视频学习资源】
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!
看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。
上面分享的腾讯、头条、阿里、美团、字节跳动等公司2019-2021年的高频面试题,博主还把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。
【Android思维脑图(技能树)】
知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。
[外链图片转存中…(img-m8WJSWPy-1715148174541)]
【Android高级架构视频学习资源】
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!