先说几句重点:
1,tinyxml 生成或解析XML非常好用
2,tinyxml 利用DOM(文档对象模型)操作XML,根节点与各个子节点相当于形成一棵树
3,只要了解tinyxml的用法,可以只new对象而不用delete。
4,tinyxml包含6个文件 tinystr.cpp , tinystr.h , tinyxml.cpp , tinyxmlerror.cpp , tinyxml.h , tinyxmlparser.cpp
5,来个官网说明的class inheritance,官网地址:http://www.grinninglizard.com/tinyxmldocs/index.html
This inheritance list is sorted roughly, but not completely, alphabetically:
直接上程序,只要看完代码,就会处理最简单的XML文档了
#include <stdio.h>
#include "tinyxml.h" int CreateXml()
{
//创建一个XML结构
TiXmlDocument* pDoc = new TiXmlDocument();
//创建一个根节点并连接到XML
TiXmlElement* pRoot = new TiXmlElement("item");
pDoc->LinkEndChild(pRoot);
//创建一个name子节点并连接根节点下
TiXmlElement* nameElement = new TiXmlElement("name");
pRoot->LinkEndChild(nameElement);
nameElement->SetAttribute("ID","");
TiXmlText* nameContent = new TiXmlText("opop");
nameElement->LinkEndChild(nameContent); TiXmlElement* addrElement = new TiXmlElement("addr");
pRoot->LinkEndChild(addrElement);
TiXmlText* addrContent = new TiXmlText("guangzhou");
addrElement->LinkEndChild(addrContent); TiXmlElement* telElement = new TiXmlElement("tel");
pRoot->LinkEndChild(telElement);
TiXmlText* telContent = new TiXmlText("");
telElement->LinkEndChild(telContent); TiXmlElement* emailElement = new TiXmlElement("email");
pRoot->LinkEndChild(emailElement);
TiXmlText* emailContent = new TiXmlText("opop@qq.com");
emailElement->LinkEndChild(emailContent);
//保存到文件
pDoc->SaveFile("test.xml");
delete pDoc; //应该是必要的
return ; } int ReadXml()
{
//创建一个XML结构并载入文件内容
TiXmlDocument* pDoc = new TiXmlDocument();
pDoc->LoadFile("test.xml");
pDoc->Print();
//获取根节点
TiXmlElement* pRoot = pDoc->RootElement();
printf("%s\n",pRoot->Value());
//获取根节点下的子节点并打印其内容
TiXmlElement* pChild = pRoot->FirstChildElement("name");
printf("%s\n",pChild->FirstChild()->ToText()->Value()); pChild = pRoot->FirstChildElement("addr");
printf("%s\n",pChild->FirstChild()->ToText()->Value()); pChild = pRoot->FirstChildElement("tel");
printf("%s\n",pChild->FirstChild()->ToText()->Value()); pChild = pRoot->FirstChildElement("email");
printf("%s\n",pChild->FirstChild()->ToText()->Value()); delete pDoc;//应该是必要的
} int main() { CreateXml(); ReadXml(); return ; }
结果如下:
最后再说一个重点:关于delete的问题
先看下面一段官方代码:只有new,没有delete
void write_simple_doc2( )
{
// same as write_simple_doc1 but add each node
// as early as possible into the tree. TiXmlDocument doc;
TiXmlDeclaration * decl = new TiXmlDeclaration( "1.0", "", "" );
doc.LinkEndChild( decl ); TiXmlElement * element = new TiXmlElement( "Hello" );
doc.LinkEndChild( element ); TiXmlText * text = new TiXmlText( "World" );
element->LinkEndChild( text ); doc.SaveFile( "madeByHand2.xml" );
}
Both of these produce the XML:
<?xml version="1.0" ?>
<Hello>World</Hello>
对比完就发现了,只要代码中TiXmlDocument 对象不要在堆中new,直接在栈中生成,那么,就不需要任何delete操作,而且必须不能delete,否则就出问题了。
原因很简单,只要TiXmlDocument 对象这个基本结构被销毁了,所有的节点会被自动销毁,源代码实现了该功能
所以,使用时只要保证TiXmlDocument 类型的对象正确被释放就可以了
TinyXML 的简单介绍以及使用的更多相关文章
-
[原创]关于mybatis中一级缓存和二级缓存的简单介绍
关于mybatis中一级缓存和二级缓存的简单介绍 mybatis的一级缓存: MyBatis会在表示会话的SqlSession对象中建立一个简单的缓存,将每次查询到的结果结果缓存起来,当下次查询的时候 ...
-
利用Python进行数据分析(7) pandas基础: Series和DataFrame的简单介绍
一.pandas 是什么 pandas 是基于 NumPy 的一个 Python 数据分析包,主要目的是为了数据分析.它提供了大量高级的数据结构和对数据处理的方法. pandas 有两个主要的数据结构 ...
-
利用Python进行数据分析(4) NumPy基础: ndarray简单介绍
一.NumPy 是什么 NumPy 是 Python 科学计算的基础包,它专为进行严格的数字处理而产生.在之前的随笔里已有更加详细的介绍,这里不再赘述. 利用 Python 进行数据分析(一)简单介绍 ...
-
yii2的权限管理系统RBAC简单介绍
这里有几个概念 权限: 指用户是否可以执行哪些操作,如:编辑.发布.查看回帖 角色 比如:VIP用户组, 高级会员组,中级会员组,初级会员组 VIP用户组:发帖.回帖.删帖.浏览权限 高级会员组:发帖 ...
-
angular1.x的简单介绍(二)
首先还是要强调一下DI,DI(Denpendency Injection)伸手获得,主要解决模块间的耦合关系.那么模块是又什么组成的呢?在我看来,模块的最小单位是类,多个类的组合就是模块.关于在根模块 ...
-
Linux的简单介绍和常用命令的介绍
Linux的简单介绍和常用命令的介绍 本说明以Ubuntu系统为例 Ubuntu系统的安装自行百度,或者参考http://www.cnblogs.com/CoderJYF/p/6091068.html ...
-
iOS-iOS开发简单介绍
概览 终于到了真正接触IOS应用程序的时刻了,之前我们花了很多时间去讨论C语言.ObjC等知识,对于很多朋友而言开发IOS第一天就想直接看到成果,看到可以运行的IOS程序.但是这里我想强调一下,前面的 ...
-
iOS开发多线程篇—多线程简单介绍
iOS开发多线程篇—多线程简单介绍 一.进程和线程 1.什么是进程 进程是指在系统中正在运行的一个应用程序 每个进程之间是独立的,每个进程均运行在其专用且受保护的内存空间内 比如同时打开QQ.Xcod ...
-
iOS开发UI篇—UITabBarController简单介绍
iOS开发UI篇—UITabBarController简单介绍 一.简单介绍 UITabBarController和UINavigationController类似,UITabBarControlle ...
随机推荐
-
Collections.unmodifiableMap
1. Collections.unmodifiableMap 是什么? Java的官方解释: public static <K,V> Map<K,V> unmodifiable ...
-
简单Java算法程序实现!斐波那契数列函数~
java编程基础--斐波那契数列 问题描述:一只青蛙一次可以跳上1级台阶,也可以跳上2级.求该青蛙跳上一个n级的台阶总共有多少种跳法. 思路:可能出现的情况:(1) n=1 ,一种方法 ;(2)n=2 ...
-
IOS 支付宝 SDK 申请
https://b.alipay.com/order/productDetail.htm?productId=2013080604609654&tabId=4#ps-tabinfo-hash
-
Uva - 1593 - Alignment of Code
直接用<iomanip>的格式输出,setw设置输出宽度,setiosflags(ios::left)进行左对齐. AC代码: #include <iostream> #inc ...
-
SV coverage
covergroup是对coverage model的一种包装,每个covergroup可以包含: 1) sync event来触发采样, 2) 很多coverpoint, 3) cross cove ...
-
Swift5 语言指南(四) 基础知识
Swift是iOS,macOS,watchOS和tvOS应用程序开发的新编程语言.尽管如此,Swift的许多部分对您在C和Objective-C中的开发经验都很熟悉. 雨燕提供了自己的所有基本C和Ob ...
-
vue中常用的两中页面刷新的方式和页面回退
这个方法的参数是一个整数,意思是在 history 记录中向前或者后退多少步,类似 window.history.go(n) router.push(location) 想要导航到不同的 URL,则使 ...
-
并发编程(四)TaskFuture
并发编程(四)TaskFuture ExecutorService executorService = Executors.newSingleThreadExecutor(); Future<O ...
-
【RF库Collections测试】Get From List
Name:Get From ListSource:Collections <test library>Arguments:[ list_ | index ]Returns the valu ...
-
比赛安排(穷举法或dfs)
比赛安排 时间限制: 1 Sec 内存限制: 125 MB提交: 11 解决: 10[提交][状态][讨论版][命题人:外部导入] 题目描述 设有2n(n<=6)个球队进行单循环比赛,计划在 ...