一种基于简单递归思想的易操控xml解析封装(C++)

本文由 @lonelyrains 出品,转载请注明出处。 
文章链接: http://blog.csdn.net/lonelyrains/article/details/45093007


技术要点:

1、基础xml解析库:tinyxml

2、XmlTree类

3、重载[],返回XmlTree类

4、实现Count函数,返回本级目录子节点的数目


针对如下的CMyString strRequestXml:(为了说明功能,把request结点分成两部分写)

<?xml version='1.0' encoding='utf-8'?>
<request version = '1.0' name = 'updateMainView'>
<request>
	<requestType>updateUI</requestType>
	<view>
		<viewType>mainView</viewType>
		<viewId>view_1</viewId>
		<event>click</event>
		<listView>
			<id>listView_mainView</id>
			<selectedId>item_2</selectedId>
		</listView>
	</view>
</request>

可以实现:
1、实现基于字符串的构造函数:XmlTree *requestXml = new XmlTree(strRequestXml) ;
2、重载[]实现子XmlTree的子对象数组:XmlTree **subViewRequestXml = requestXml["request"][1]["view"];
3、实现当XmlTree只有一个结点时可以强转成CMyString: requestXml["request"][1]["view"]["event"].CMyString(),并可以Get/Set和直接赋值
4、实现本级子节点数目的Count: requestXml["request"][1].Count() == 2
5、实现非树形表示时的结点访问: reuestXml["request"][0]["version"] == "1.0"
6、扩展实现,可以考虑以后再扩展:XmlTree的插入和删除:requestXml["view"].insert(subViewRequestXml)


二级指针表示一级指针数组的第一个元素时可以互转,没问题,就像二维数组 arrayXY[][] 的 arrayXY == arrayXY[0];
所以上面的XmlTree **subViewRequestXml = requestXml["request"][0]["view"]; 
可以写成 XmlTree *subViewRequestXml = requestXml["request"][0]["view"]; 也可以写成XmlTree *subViewRequestXml = requestXml["request"]["view"];

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值