tinyxml源代码解析(一)

在科研工作中,读取和存储XML文件是最常用的操作,tinyxml是一个开源的,非常小巧和好用的XML读写工具,在此,本文将从源代码层面开始分析tinyxml,尽量做到突出细节,主题明确。

首先,tinyxml包含有tinystr.h,tinyxml,h,tinystr.cpp,tinyxml.cpp,tinyxmlerror.cpp,tnyxmlparser.cpp这几个项目,我们就从最基本的也是tinyxml自己定义的数据结构tinystr开始说起吧:tinystr是tinyxml自己定义的类似于string的数据结构,包含有自己的属性和方法,很有借鉴意义。它定义了一个叫做TiXmlString的类。其中定义了两个静态对象。

static const size_type npos;
static Rep nullrep_;
由于静态对象在进程创建的时候就创建了,并在进程结束的时候结束,所以在对象创建之前就有了npos和nullrep_,npos作为函数运行错误判断的标识,而nullrep_是作为结构体Rep的对象,结构体Rep的代码如下:
struct Rep
	{
		size_type size, capacity;
		char str[1];
	};
包含了TiXmlString中最重要的三个属性,长度size,容量capacity,以及本体str[1](str是一个指针常量,指向一个固定地址,表示TiXmlString的本体)。npos和nullrep_初始化如下:
const TiXmlString::size_type TiXmlString::npos = static_cast< TiXmlString::size_type >(-1);
TiXmlString::Rep TiXmlString::nullrep_ = { 0, 0, { '\0' } };
另外定义了一个Rep类型的指针rep_作为初始化时候的重要参照。

下来就是TiXmlString的几个构造函数,每一个都在初始化的时候使用了*rep_,使得最重要的三个参数进行了初始化。

下面,我们来看TiXmlString中的几个方法,再看函数的时候我们要结合这个类的属性来看,那么首先我看到的就是init()函数,作为初始化函数,TiXmlString写的还是很不错的,我们来看看代码:

	void init(size_type sz, size_type cap)
	{
		if (cap)
		{
			const size_type bytesNeeded = sizeof(Rep) + cap;
			const size_type intsNeeded = ( bytesNeeded + sizeof(int) - 1 ) / sizeof( int ); 
			rep_ = reinterpret_cast<Rep*>( new int[ intsNeeded ] );

			rep_->str[ rep_->size = sz ] = '\0';
			rep_->capacity = cap;
		}
		else
		{
			rep_ = &nullrep_;
		}
	}
全程都使用rep_指针,首先根据传入的字符串长度算出需要的内存空间,然后回归到rep_,简单明了。TiXmlString这个类的几乎所有函数最终都会返回Rep结构中的变量,可见Rep结构的重要性,所以说,以后在设计类的时候可以借鉴这个方法,把最本质的属性提炼出来作为一个结构指针,然后就可以简化类的设计。以上全部都是个人的理解,有不当之处在所难免,欢迎大家一起交流。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值