更好更快更高效解析JSON说明

现在来一个实例解析类,直接就把解析JSON到QVariant去了。唯一不足的是没有搞错误处理,具体方法也请各位自行参考json-c的发行文档,这样比较方便叙述,STL或者Boost我都没有认真接触过,不方便写。

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition – December 1999的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。 这些特性使JSON成为理想的数据交换语言。

话说JSON在Web上应用得非常不错,XML虽然想法很好,但是冗长,解析又麻烦。而JSON作为Javascript的字符描述语言,根本不用手动解析,直接交给Javascript,Eval便可得到结果。而PHP 5.2 以上,更内置了JSON的解析函数,一个函数便把PHP的对象转换为JSON,比XML来得快得多、方便得多(话说PHP干对象的Serialize和Unserialize是它的强项  )。

今天本文就来说说在C和C++上如何来读取JSON。实际上解析JSON是比较简单的,难点在于读取。另外,以QT为例,这样比较方便叙述,STL或者Boost我都没有认真接触过,不方便写。#t#

现在JSON解析库满天飞,没有必要再自己写个了,除非是商业程序  。我试过JsonCPP, QJson, Json-Spirit, jaula等C++的库。遇到总总问题,有不支持中文(UTF-8编码也不行)、不方便在Windows下编译、体积过于臃肿等毛病,最终的选择是C库json-c,因为Google看到一篇文章对JSON的各个C库的优点比较,说Json-C兼容性最好,而且支持中文(使用UTF-8)。

编译仍然不是很方便,需要使用configure和GCC。这样就需要MSYS或者Cygwin了,各位Windows大大需要编译的话,劳请各位自己Google,安装最基本的MSYS或者Cygwin,以便使用Bash。另外,MinGW也是必不可少的啦,因为要用GCC和Make嘛。

如若在C++下使用C的库,头文件需要特殊处理,解析JSON因为C编译器及C++编译器编译出来的中间代码的符号不一致,如若不经处理,最后在链接的时候定会出现找不到符号的问题。以下是C++的代码:

 
 
  1. #include  
  2. #include  
  3. #include  
  4.    
  5. extern "C"{  
  6. #include  
  7. #include  
  8. #include  
  9. #include  
  10. #include  
  11. }  
  12.    
  13. .....  
  14. // 忽略上下文的其它代码,关注我们要的解析方法  
  15.    
  16. // 1) 解析数组  
  17. char * json_string = " [ 10, 20, \"nice\" ] ";  
  18. struct json_object *obj, *temp_obj;  
  19. QList< QVariant > data;  
  20.    
  21. obj = json_tokener_parse( json_string ); /* 此时的Obj是一个Array */  
  22. for(int i=0 ; i(obj) ; i++ ){  
  23.     temp_obj = json_object_array_get_idx(obj, i ); /* 获取数组的第 i 个元素,作为 temp_obj 保存 */  
  24.     switch( json_object_get_type( temp_obj ) {  /* 判断 temp_obj 的类型 */  
  25.       case json_type_string:  /* 若是字符串 */  
  26.         data.append( json_object_get_string(temp_obj) )  
  27.       break;  
  28.    
  29.       case json_type_int: /* 若是整数 */  
  30.         data.append( json_object_get_in(temp_obj) )  
  31.       break;  
  32.    
  33.       default: /* 其它的类型先不管了 */  
  34.       break;  
  35.     }  
  36.  }  
  37. }  
  38.    
  39. // 2) 解析对象  
  40. char * json_string = " { one: \"good\", \"two\":2 } "  
  41. struct json_object *obj, *temp_obj;  
  42. QMap< QString,QVariant > data;  
  43.    
  44. obj = json_tokener_parse( json_string );  
  45. json_object_object_foreach( obj, key, value ){ // 这里的key和Value不需要提前声明。在宏里作者就给声明了 -_-|||  
  46.    
  47.  switch( json_object_get_type( value ) {  
  48.       case json_type_string:  /* 若是字符串 */  
  49.         data.insert( key, json_object_get_string(value) )  
  50.       break;  
  51.    
  52.       case json_type_int: /* 若是整数 */  
  53.         data.insert( key, json_object_get_in(value) )  
  54.       break;  
  55.    
  56.       default: /* 其它的类型先不管了 */  
  57.       break;  
  58.  }  
  59. ... 

网页题目:更好更快更高效解析JSON说明
URL标题:http://www.shufengxianlan.com/qtweb/news28/392878.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联