daybits的rust version

最近用rust重写了daybits的java版。已经在淘系一些场景大规模使用,性能比温少的java版本快30%以上。java

开源在https://github.com/maomaoguan/daybits4rgit

整个rust编写过程仍是比较闹心的。rust是门比较有趣的语言,他的pre-compilation很强大。C++或是Java运行期的一些问题,C++的内存释放问题,Java的GC避免,这些都在rust的编译过程会被抓出来,让你编译不过。github

不过,也为此付出了代价,好比为了确保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指针

相关文章
相关标签/搜索