锟截革拷锟斤拷【原创】暂 无题(预计搞笑类 he
————正文————
血禁封印这种东西,虽说知道的人不少,而且是被各个血继家族广泛使用,但各个家族也在基础上发展出不同的形式来。虽然女孩身上并没有,但静流也是觉得不会认错宇智波一族的封印术式。这东西的私密性和屁股上有颗小痣也差不多了。
被静流这么一提,柱间也反映过来了,他急吼吼的转向斑道:“斑……”
不过才听见自己的名字,斑离开抬手阻止道:“停!”
柱间顿住,眨巴眨巴眼睛,可怜兮兮的还是想说点什么:“可是……”
“闭嘴!”斑这时也是火气上来了,一拍桌子冲柱间吼了一句,而后眼神严厉的扫视了在座的人一圈。
大家看着被斑一拍之下‘咔咔’走开裂纹的木桌,识相的转开了眼睛,有点刻意的装作好像什么事都没发生一般避开他的眼神。当然佐助除外,佐助还瞪了他一眼。
‘你发什么神经!’斑猜佐助是这个意思。感觉自己快要被憋死了,斑拉起佐助道:“你跟我走。”而后转向剩下的人道:“你们继续。”
静流也站起身,似笑非笑的在斑和柱间之间巡视了一圈,向柱间和松平告辞道:“我对这方面实在是了解不多,我也先告辞了。”而后又和桃华、阿苑和龙告辞,反而比斑和佐助先走了。
佐助一脸的不爽和不解跟着斑回了家。进了门斑竟然什么都不想管了一样的很光棍的躺在廊道上晒太阳。佐助坐到他边上,皱着眉道:“你就这么回来,工作谁干?”
斑换了个让自己更舒服的姿势:“谁爱干谁干。”
佐助忍了忍还是问道:“血禁封印是什么?”
斑一翻身做起来,盯着佐助细看了好一会儿,确定他确实不知道,叹气了口气无奈的向佐助详细的解释了一遍。
听过斑的解释,佐助倒是忽然想起来了:“你一说,我倒是想起来了,好像逆写封印就是窃取血继界限的过程中被发现的。那么柱间是倒真是很擅长封印术啊,看到最后的版本几乎立刻就发觉了来源。”
现在是说这个的时候吗?斑顺了下头发,彻底放弃道:“这回你倒是不用担心静流和柱间有什么了。”
听到这个结论佐助倒是很高兴,不过:“为什么?”
斑叹气道:“静流以为我和柱间有暧昧。”
听到斑说的这个,佐助撇了下嘴:“这算什么暧昧。”佐助显然并不能理解斑的苦恼,不过他还是安慰道:“管他们说什么呢。我听说扉间之前有给涡潮村去信邀请漩涡一族的公主漩涡水户,她应该很快就来了。算算时间她应该很快就会和柱间结婚,到时候不管什么流言自然都会不攻自破。”
虽然听着是这样,但斑却觉得事情似乎不会这么顺利,但最终只道:“希望如此吧……”这么说着斑又想起来问刚才佐助抖出来的那个让他都有点受到了惊吓的术:“你那个什么什么的术真的能让随便两个人生出孩子来?”
“理论上能。”佐助浑不在意的耸了下肩。
听到这个答案斑倒是也觉得果然如此:“我就觉得不会这么简单。”
佐助也愿意和斑多说两句:“先说催生胚胎,那真不是一点运气能成功的。那是得运气逆天了,瞎猫碰上死耗子的几率。再说拓印灵魂这种事,只是听起来简单而已。”
佐助很严肃的继续道:“要能够成功拓印一个人的灵魂,那精神力至少得倍于对方。假如一般普通人的精神力的平均值是一的话……精神力能够达到二的人整个忍界都找不出多少来”说完这个佐助愣了愣道:“估计大半都在宇智波了。三勾玉外加天赋好一点应该勉强能超过二。”
最后佐助很有些嘲讽的说道:“灵魂种子的产生也是几率性的。而且被拓印的人在这个过程中相当于将自己的一切都坦露出来,而拓印的人只要他想,连对方四五岁时做过什么梦估计都能知道,稍稍遮掩就会失败。如果你成功用刚才那个术式拓印了一个人的灵魂,这个人要么是个傻瓜,要么是你的信徒。”
————C————
贴吧:柱斑作者:卸香无 2015-12-03 15:56
锟截革拷锟斤拷我是真菜丨东西到了,直播装机!
u盘启动器好像被我玩坏了,进不了大白菜界面……才把硬盘区分好来着,第一次就是方!
贴吧:电脑作者:如果仗剑天涯 2016-03-08 16:13
锟截革拷锟斤拷android培训【03-08】Android学
4.Fast Json高效的原因,为什么推荐使用Fast Json


Fast json高效自然而然是有它的原因的..我主要针对几点来说说..因为我并没有完全的看完Fast Json的源码..只是自己的一些见解,说的也就不是非常的全面..
(1)使用SerializeWriter
将数据封装成Json的时候使用SerializerWriter来完成,通过对字符串的追加将数据转换成Json字串.并且其内部提供了一些优化针对减少数组越界的判断.(减少了越界的判断确实能够提高一部分效率)
ThreadLocal来缓存buf,写入数据必然需要使用缓存来存放字符串的内存地址,但是每次序列化的时候都需要重新分配buf的内存空间,为了避免多次申请内存空间以及gc的调用,因此将内存保存到了ThreadLocal中,当再次进行序列化的时候只需要从ThreadLocal中取出内存就可以了.
并且ThreadLocal不仅仅可以缓存内存地址,当我们对Json数据进行解析的时候也会使用到它提供的缓存..当我们在解析Json的时候,我们读取到的key值可以被保存在一个叫sbuf的缓冲区中,只要这个缓冲区不被释放掉,那么再次读取的时候只需要从缓冲中读取到相关的字符串序列即可,没必要去new一个新的字符串对象,从而导致内存空间的开辟以及不必要的gc调用..
(2)使用asm来避免反射机制的使用
asm不是一个算法,它是字节码框架技术,它可以避免使用Java中的反射机制从而获取到一个类中的所有成员变量和方法,反射机制同样也可以实现,但是反射机制的一大弊病就是耗费时间.使用反射中间会生成大量的临时变量从而导致gc的频繁调用.(避免了反射的使用,自然性能上也有了一定的优化) 至于asm技术我没有进行彻底的研究..可能以后会写..有兴趣的大家可以自己去研究研究..
(3)使用IdentityHashMap去优化性能.
因为Fast Json每种类型都对应一种解析方式,也就出现了<class,JavaBeanSerializer>的映射关系,那么映射自然就需要使用有映射关系的集合,也就是HashMap<K,V>,但是HashMap并不是线程安全的,也就是在并发环境下会导致死循环的出现.因此在并发情况下我们就需要ConcurrentHashMap,但是比HashMap的性能要差,因为需要使用lock()等方法控制多线程的安全问题.安全就失去了效率,因此IndentityHashMap集合就在Fast Json中开发.他的内部去除了transfer方法,使得它能够在并发的情况下也能保证安全性.同样效率也就不会受到影响。
(4)Deserializer的主要优化算法..
Deserializer也成为反序列化过程,也就是将Json数据转化成Java Bean形式.也是优化精力最多的地方.
基于token的预测分析:
解析Json 需要使用到词法处理,Fast Json使用了基于预测的词法分析方式,比如说:比如key之后,最大的可能是冒号":",value之后,可能是有两个,逗号","或者右括号"}" 这样的预测分析。
public void nextToken(int expect) {
/* */ while (true) {
/* 297 */ switch (expect)
/* */ {
/* */ case 12:
/* 299 */ if (this.ch == '{') {
/* 300 */ this.token = 12;
/* 301 */ this.ch = this.buf[(++this.bp)];
/* 302 */ return;
/* */ }
/* 304 */ if (this.ch == '[') {
/* 305 */ this.token = 14;
/* 306 */ this.ch = this.buf[(++this.bp)];
/* 307 */ return;
/* */ }
/* */ case 16:
/* 311 */ if (this.ch == ',') {
/* 312 */ this.token = 16;
/* 313 */ this.ch = this.buf[(++this.bp)];
/* 314 */ return;
/* */ }
/** 中间一堆....*/
if ((this.ch != ' ') && (this.ch != '\n') && (this.ch != '\r') && (this.ch != '\t') && (this.ch != '\f') && (this.ch != '\b')) break;
/* 419 */ this.ch = this.buf[(++this.bp)];
/* */ }
/* */
/* 423 */ nextToken();
/* */ }

预测分析的源代码就是上面粘贴的,只是粘贴了一部分,其实就是对下一个token的预测判断,这样可以帮助我们尽最快的速度拿到token..简单的说一下token的概念..
//这是一个Json字串..其中token单引号引起的部分每一个单引号引起的部分就是一个token这里一共有13个token..{ "id" : 123, "name" : "aa", "salary" : 56789} //json字串 '{' ' "id" ' ':' '123' ',' ' "name" ' ':' ' "aa" ' ',' ' "salary" ' ':' '56789' '}'
这样token的概念就没那么难理解了..
(5)Sort field fast match算法
Fast Json在封装和解析的时候都是默认使用这个算法的,就是以有序的方式将Json 字符串进行保存,如果数据保存的形式是有序的,那么就使用优化算法,不用对每一个token进行处理..只需要处理一部分的token就可以了..也正是因为这个原因,使得Fast Json在解析Json的时候可以减少50%的token...这样效率上就有了空前的变化...如果不是有序的我们就需要一个一个进行分析了,然后从中取出key对应的value值.
就那上面那条Json数据来说吧,如果key值是有序的,那么只需要处理6个token就可以了,但是如果是无序的,就需要处理13个token..处理13个token不难理解..就是对扫描整个字符串,然后处理每一个token不就完事了..但是如果是有序的,那么为什么只需要处理6个token呢?我看了很多人的博客都没有对这块进行讲解..也就使得我也非常的迷茫..
我自己的理解是这样的:其实对不对我自己也不是非常的确定..(如果不对,大家请指出)
之所以只需要处理6个token就是只需要对key和value值进行处理,三对key,value对应的也是6个token,因为我们使用了预测分析,那么自然而然就知道了Json的数据格式,有了这个数据格式,那么那些符号类的token就可以直接跨越过去,我们已经匹配到了key那么自然就预测到key后面有一个","那么这个","我们就不需要处理了,只需要处理","后面的value了..因此符号类的token是没必要处理的,但是为什么要有序,因为我们是将每一条的Json数据转化成字符数组的形式,在匹配key值的时候我们是按照字符数组进行匹配,如果每一条的顺序都不一样,那么就不能使用一条规则去使者多条数据遵循这一个原则进行解析..因此才进行排序,可以减少对token的读取和处理..(个人理解..不对的话,请指出..)
这也就是Fast Json迅速的原因..自然有很多地方的东西没说到..Fast Json说是最快..是不是最快我们说了不算,但是Fast Json确实融入了很多的思想..还是很不错的一个解析Json的api接口..
至于用不用取决于大家..也没必要去争执谁解析Json最快..没什么意义..
原本其实想深入的研究一下,总结一下所有的原因和思想..但是看到很多人写的东西都是九牛一毛..抄来抄去的..没写出核心的东西..等自己真正有时间的时候再去解读一下源码再深入的写吧..
PS:最后只是吐槽一下..如果有人看着不爽..请不要喷我..谢谢!


最后说一下自己学这块的感悟:说实话之所以在Sort Field Fast match算法不是很明白的原因就是没有看到关于这块写的非常优秀的文章,看了挺多人的文章,看着是很厉害,但是写出来的东西大部分都是不清不楚,不明不白,我可以理解使用大量的专业术语(其实就是不说人话)..有的呢就是直接把人家写的东西直接粘贴过去,估计自己都没理解到底是怎么一回事..搬别人的东西不是不可以,只是在搬的时候我们也去想一想,最后结合我们自己的思想写到博客上,那才叫自己真正的学了,博文里才有自己的思想..直接抄来抄去,连改都不改动一下...真的很没意思..


感觉真的挺无力的,Sort这块纠结了很长时间到底要不要写出来,就怕误人子弟...很多博文写的东西只是写一个开头,就拿这个算法为什么只处理了6个token,没有什么过多的解释,什么是asm也没有什么过多的解释..(一开始还以为asm是算法,结果查了一下asm算法和图像处理有关,很明显就弄错了,后来才明白asm是字节码框架技术)..虽然我自己很菜..但是我能保证每一篇文章都是用很大的心思去写,自己心安就行...

贴吧:android培训作者:傻傻的笨老鼠01 2016-03-08 16:16

大家都在搜

  • 东涌线
  • 荃湾线
  • 风筝线
  • 拉长线
  • 西铁线
  • 屯马线
  • 线 线
  • 穿线管