最强大的Json模块源码多线程共享

陌路 2019-10-12 17:05:28
导读模块默认为多线程方式初始化的COM库,值得注意的是模块中有很多命令都会卸载多线程初始化(比如正则、网页访问等都会调用卸载CoUninitialize,他们会造成程序崩溃,如果要兼容模块请不要调用本方法多线程初始化COM,并在每个线程首次使用Json类的方法前加上单线程初始化COM。

最强大的Json模块源码多线程共享

这样初始化的变量不支持多线程共享,只能被最先使用的线程使用。

依托于对象引用机制,无论对哪个子对象进行改变,都能稳定同步更新,而且本版集成了JSONP跨域格式的解析功能,再也不用为这样的数据格式伤脑筋了“_callback1451577600({code:-10086,msg:'密码错误!'})”。
?其他注意事项

复制变量不可以使用如下方式直接复制(因对象引用机制有着引用数计次,直接复制会导致计次异常而提前释放内存继而引发程序崩溃)。
错误的方法演示:

面向对象

类中两大关键方法,均返回Json类型对象。
Json.I() '以数组下标方式获得成员,返回一个Json类型的对象(即返回一个和调用类型一样的对象)。
Json.K() '以键名方式获得成员,返回一个Json类型的对象
意味着一句代码可以无限层次进入子对象中,比如这样的json中:
{data:[ obj:{ code: 8 , data:[ msg:{ error :-8 ,errorData:{ text: 'Incorrect password' , date:1451577600}} ] } ]}
只需如下代码便可获得错误原因
错误原因=Json.K("data").I(0).K("data").K("msg").K("errorData").K("text").取文本()
当然新的版本还保留了传统的表达式方式取得对象,虽然已不推荐使用(表达式方式没有IDE提示,而且需要自己检查语法错误等缺点),具体用法如下:
错误原因=Json.X("data[0].data.msg.errorData.text").取文本()