TiXmlString& TiXmlString::assign(const char* str, size_type len) { size_type cap = capacity(); /** * 如果str的长度大于当前的容量,那么直接生成一个临时的TiXmlString对象tmp,并赋值str, * 然后将tmp的数据和本对象的交换。 * 这样在此函数中返回时,以前的数据空间将在销毁tmp时同时销毁,可防止内存泄漏。 * * 第二个判断条件是当当前容量过大时也这么做,有助于节省空间。 * * 这里面tmp对象很有意思,可以帮助销毁以前的空间,防止内存泄漏! */ if (len > cap || cap > 3*(len + 8)) { TiXmlString tmp; tmp.init(len); memcpy(tmp.start(), str, len); swap(tmp); } else { memmove(start(), str, len); set_size(len); } return *this; }
void TiXmlString::reserve (size_type cap) { if (cap > capacity()) { TiXmlString tmp; tmp.init(length(), cap); std::memcpy(tmp.start(), data(), length()); swap(tmp); } }
TiXmlString& TiXmlString::assign(const char* str, size_type len) { size_type cap = capacity(); if (len > cap || cap > 3*(len + 8)) { TiXmlString tmp; tmp.init(len); std::memcpy(tmp.start(), str, len); swap(tmp); } else { std::memmove(start(), str, len); set_size(len); } return *this; }