C++类库Pugixml与rapidxml性能评测
1.xml文件加載的速度,pugixml不如rapidxml。
2.使用的便利性來說,pugixml不如rapidxml。
綜上,技術(shù)選型可以優(yōu)先考慮rapidxml。
網(wǎng)絡(luò)上搜索了一下看了有說pugixml效率比rapidxml高,原博客地址:https://blog.csdn.net/u012209790/article/details/56014779?utm_medium=distribute.pc_relevant.none-task-blog-baidujs_title-2&spm=1001.2101.3001.4242
為了更好的體現(xiàn)性能,都采用當(dāng)前官網(wǎng)最新版本,現(xiàn)在能下載到最新的分別是pugixml-1.11,rapidxml-1.13。
由于這個是用于嵌入式開發(fā),我這里采用arm-A8的cpu來運(yùn)行測試。
兩個C++類庫文件都比較少
下載了pugixml-1.11.zip 文件解壓后有很多文件,有例子工程文件,其實(shí)真正有用的是src里面的源碼,提取源碼刪除其他東西后就如下圖的樣子
下載了rapidxml-1.13.zip文件解壓后就是下圖的樣子
編寫測試的cpp文件
#include <iostream> #include "pugixml-1.11/pugixml.hpp" #include "pugixml-1.11/pugiconfig.hpp" #include <sys/time.h>#include "rapidxml-1.13/rapidxml.hpp" #include "rapidxml-1.13/rapidxml_print.hpp" #include "rapidxml-1.13/rapidxml_utils.hpp" using namespace std;#define TEST_TIMES 10int pugixmltestmain( void ) {pugi::xml_document doc;timeval starttime, endtime;double timeuse = 0.;double timeAverage = 0.;for( int i = 0; i < TEST_TIMES; ++i ){gettimeofday( &starttime, 0 );if( !doc.load_file( "xml/login.xml" ) ){cout << "failed in load xml file! _ " << i << endl;continue;}gettimeofday( &endtime, 0 );timeuse = 1000000. * (endtime.tv_sec - starttime.tv_sec) + endtime.tv_usec - starttime.tv_usec;timeuse *= 0.001 ;cout << " reading files costs : " << timeuse << "ms" << endl;timeAverage += timeuse;}timeAverage /= TEST_TIMES;cout << " \n** The end *******************\n pugixmltest the average costs = " << timeAverage << "ms\r\n\r\n" << endl;return 0; }using namespace rapidxml; using std::cout; using std::endl;int rapidxmltestmain() {timeval starttime, endtime;double timeuse = 0.;double timeAverage = 0.;//< parse xmlfor( int i = 0 ; i < TEST_TIMES; ++i ){rapidxml::file<> filename( "xml/login.xml" );xml_document<> doc;gettimeofday( &starttime, 0 );doc.parse<0>( filename.data() );gettimeofday( &endtime, 0 );timeuse = 1000000. * (endtime.tv_sec - starttime.tv_sec) + endtime.tv_usec - starttime.tv_usec;timeuse *= 0.001 ;cout << " reading files costs : " << timeuse << "ms" << endl;doc.clear();timeAverage += timeuse;}timeAverage /= TEST_TIMES;cout << " \n** The end *******************\n rapidxmltest the average costs = " << timeAverage << "ms\r\n\r\n" << endl;return 0; }int main() {pugixmltestmain();rapidxmltestmain(); }如果沒有xml文件 就在測試目錄增加一個xml目錄,里面創(chuàng)建login.xml
Xml內(nèi)容如下
到這里文件都準(zhǔn)備好了,編譯,因?yàn)橛昧藀ugixml,需要把pugixml的cpp文件編譯,如果單純用rapidxml就不需要另外編譯,命令如下
arm-linux-g++ -o test xmltest.cpp pugixml-1.11/pugixml.cpp
編譯沒有問題就掛載或者拷貝到板子運(yùn)行測試
下圖是執(zhí)行結(jié)果
從測試結(jié)果就可以得出,xml文件加載的速度,pugixml不如rapidxml。
使用的便利性來說,pugixml還要編譯源碼,pugixml不如rapidxml。
那篇博文寫在2017年的,應(yīng)該是這些年兩個都有所優(yōu)化。
綜上,技術(shù)選型可以優(yōu)先考慮rapidxml。
總結(jié)
以上是生活随笔為你收集整理的C++类库Pugixml与rapidxml性能评测的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: UEditor 自定义input,复选框
- 下一篇: raw socket编程实例