干货总结|快速构造String对象及访问其内部成员的技巧

一、相关知识JDK String的实现

字符串在JDK 8及JDK 9之后的实现有很大不同的。JDK 8中,String的结构是这样的:

1.1 String JDK 8的实现

1.2 String JDK 9及之后版本的实现

JDK9之后,通过byte[]来保存value,通过code字段区分是LATIN1或者UTF16。大多数的字符串都是LATIN1。针对这种情况,我们构造字符串或者对字符串进行编码为二进制时,针对性做ZeroCopy的实现,可以获得极致的性能。

二、相关知识Unsafe

JDK 8之后提供sun.Unsafe可以做一些原生的操作,性能更好,不安全,错误的调用会导致JVM Crash。如果用对了,能提升性能。Unsafe能帮你绕过任何限制。

三、相关知识Trusted MethodHandles.Lookup

JDK 8开始支持Lambda,为了方便将一个Method映射为一个Lambda Function,避免反射开销。java.invoke.LambdaMetafactory可以实现这一功能,但这个也受限于可见性的限制,也就是说不能调用私有方法。有一个技巧,结合Unsafe,可以在不同版本的JDK都能构造一个Trusted MethodHandles.Lookup来绕开可见性的限制,调用任何JDK内部方法。如下:

注意:在IBM OpenJ9 JDK 8/11版本上面的实现受到可见性限制,需要做额外处理,参考FASTJSON2 JDKUtils#trustedLookup的代码 :

https://github.com/alibaba/fastjson2/blob/fastcode_demo_20221218/core/src/main/java/com/alibaba/fastjson2/util/JDKUtils.java#L254

四、零拷贝构造String对象

快速构造字符串的关键是要做减少拷贝,甚至零拷贝,在JDK 8、JDK 9~15、JDK 16及之后的版本的实现都不一样。

4.1 JDK 8零拷贝构造String对象的实现

在JDK8中,实现零拷贝构造String对象,需要调用其构造函数String(char[], boolean),比如:

由于String(char[], boolean)方法不是public的,上面的代码会报错,要通过反射构造一个TRUSTED的MethodHandles.Lookup,然调用String的内部方法,映射成一个BiFunction,代码如下:

4.2 JDK9及之后版本实现零拷贝构造String对象的实现

在JDK 9~JDK 15中,我们要构造一个这样的Function用于零拷贝构造String对象:

同样,JDK 9中的String(byte[], byte)方法不是public,无法直接调用,上面的代码会报错,要构造一个TRUSTED MethodHandles.Lookup方法调用String内部方法,如下:

注意:当用户配置JVM参数-XX:-CompactStrings时,上述方法无效。

4.3 快速构造String对象应用举例

上面的例子中,根据JDK版本,在JDK 8中直接创建char[],JDK 9中直接创建byte[],然后通过零拷贝的方式构造字符串对象,这样就实现了快速格式化LocalDate到String,这样的实现远比使用SimpleDateFormat/java.time.DateTimeFormat等实现要快得多。

五、直接访问String对象内部成员

5.1 JDK 8快速访问value

5.2 JDK 9及之后版本直接访问coder & value

我们需要构造如下的函数:

但由于String.coder和value方法不是public可见的,和上面的4.2类似,要通过TRUSTED MethodHandles.Lookup构造,如下:

5.3 直接访问举例

5.4 巧用String.getBytes方法

String有一个Deprecated的getBytes方法,当有非LATIN字符时,结果不对。但当在coder为LATIN1时,可用于直接拷贝其中value,

参考实现:

FASTJSON2项目使用了上面的技巧,其中JDKUtils和UnsafeUtils有上面技巧的实现:

JDKUtils:https://github.com/alibaba/fastjson2/blob/fastcode_demo_20221218/core/src/main/java/com/alibaba/fastjson2/util/JDKUtils.java

UnsafeUtils:https://github.com/alibaba/fastjson2/blob/fastcode_demo_20221218/core/src/main/java/com/alibaba/fastjson2/util/UnsafeUtils.java

注意事项:

上面的技巧不建议新手使用,需要先清楚原理,才可使用。

最新资讯

文档百科

为什么折耳猫不能养

折耳猫不可以买,主要是因为它存在基因缺陷,而这种天生的软骨病,在发病的时候,会使折耳猫非常痛苦,并且软骨病是不能得到治愈的,只能通过服用软骨素来缓解。折耳猫因为天生的基因问题,不仅只有软骨病,它的体质也非常差,而且还有心脏病、呼吸疾病等,很多的折耳猫虽然看着很正常,但是它们随时都有可能会发病猝死。

宋钦宗仁怀皇后生有几个子女?宋钦宗赵桓几个儿子

宋钦宗赵桓子女仁怀皇后朱琏,宋钦宗赵桓的皇后,汴京祥符人。宣和七年,钦宗即位,册封朱氏为皇后。朱皇后不堪污辱,当天投水自杀身亡。),宋钦宗赵桓长子,朱皇后所出。柔嘉公主,宋钦宗赵桓之女,为皇后朱琏所生,生于1121年,卒年不详。宋钦宗宋钦宗子女简介儿子太子赵谌(1117年-?后随钦宗至五国城。

修建陵墓完毕后,最后一位工匠怎么出来呢?

这样以来,也就不需要工匠们亲自动手将石门封上,也就不存在到底怎么出来的问题了,看到这里,大家是否对中国古代工匠的聪慧感到叹为观止了呢?

失王多久急造王台

一般的蜂群在失王24小时之内就能急造王台,但是需要2-3天才能被人类发现。一般一个蜂群在失王之后,工蜂会首先得察觉到,开始紧急制造王台。蜂群中的一些青年工蜂的卵巢也会因为缺少蜂王信息素的干扰,伴随着急造王台的建造而发育,这两个过程是同时进行的。

呼吸系统专项检查内容有什么?

肺功能检查是采用一系列手段检测肺的气体交换功能。肺功能测定结果有助于判断有无通气功能障碍,以及障碍的性质和程度,可作为某些肺部疾病诊断的辅助手段。肺功能检查也可作为重要的疗效判断指标以指导和评价临床治疗。

血管造影的应用有哪些?有什么缺陷?

血管造影有时被称为常规血管造影术,以区别于CT血管造影和磁共振血管造影。血管造影提供血管的详细图像,通常是心脏,肺,脑和腿的血管,并且可以提供静止成像或录像,造影过程虽然是侵入性的,但相对安全。

CopyRight © 2000~2023 一和一学习网 Inc.All Rights Reserved.
一和一学习网:让父母和孩子一起爱上学习