最近用rust重写了daybits的java版。已经在淘系一些场景大规模使用,性能比温少的java版本快30%以上。
开源在https://github.com/maomaoguan/daybits4r
整个rust编写过程还是比较闹心的。rust是门比较有趣的语言,他的pre-compilation很强大。C++或是Java运行期的一些问题,C++的内存释放问题,Java的GC避免,这些都在rust的编译过程会被抓出来,让你编译不过。
不过,也为此付出了代价,比如为了确保Vec操作的ownership还有避免脏数据,使用Vec会很容易出现Data Moves的报错。对于我这种写惯了Java的,费解了好长时间。后来明白,因为rust担心你在index方式遍历整个数组过程中出现,1) 数组发生插入等操作 2) 因其他操作引起的Vec内部指针重新申请,导致你引用了非法的指针。检测到风险直接编译不过。取而代之的是,rust给出了几种解法,pull/pop方式遍历数组等。
还有很多对于Java同学来说比较费解的编译不过,比如borrow的对象因为ownership关系不能做mut等操作。
针对温少的Java版本,从代码结构上也做了进一步优化,哪怕只有百分之几,这个函数在数据计算场景的调用量是惊人的大。比如Calendar的存储上进一步压缩空间。在mac air上测试性能对比如下:
Java版本(每百万次调用耗时ms)
case1_parse-> cost 260
case1_output-> cost 389
case1_first-> cost 97
case1_last-> cost 29
case1_count-> cost 69
case2_or-> cost 4472
case2_and-> cost 5265.112212
rust版本(每百万次调用耗时ms)
case1_parse-> cost 337.491378
case1_output-> cost 232.794272
case1_first-> cost 115.571636
case1_last-> cost 16.853881
case1_count-> cost 43.562107
case2_or-> cost 2534.386394
case2_and-> cost 2435.115885