scala反编译工具
Ⅰ Java IDE集成开发工具: IntelliJ IDEA CE 2019
IntelliJ IDEA CE 2019 是一款功能强大的 Java 集成开发环境。它将源代码编入索引后,提供即时、智能的代码完成,以及快速的代码分析,确保编码效率与代码质量。IDE 强大的重构工具为开发者带来便捷的代码维护体验。
IntelliJ IDEA CE 2019 内置了丰富且统一的版本控制系统界面,支持 Git、SVN、Mercurial、CVS、Perforce 和 TFS 等主流版本控制系统,帮助开发者高效管理代码版本。
构建工具方面,IDE 支持 Maven、Gradle、Ant、Gant、SBT、NPM、Webpack、Grunt、Gulp 等多种构建工具。这些工具与 IDE 的无缝集成,使得自动编译、打包、运行测试、部署等操作变得更加简单高效。
在测试方面,IntelliJ IDEA CE 2019 提供了强大的单元测试支持,包括 JUnit、TestNG、Spock、Cucumber、ScalaTest、spec2 和 Karma 等主流测试框架的测试运行器和覆盖工具。开发者可以轻松执行单元测试,提升代码质量。
IDE 还内置了反编译器,无需借助第三方插件,即可查看没有源代码的库。内置终端功能,让开发者无需离开 IDE 即可执行命令,进行代码调试。
数据库工具方面,IntelliJ IDEA 提供了智能编码辅助功能,支持 sql 编辑、实时数据库连接、查询执行、数据浏览和导出,以及可视化方案管理。
应用服务器支持方面,IDE 支持 Tomcat、JBoss、WebSphere、WebLogic、Glassfish 等主流应用服务器。开发者可以轻松部署工件到应用服务器,并在 IDE 中直接调试已部署的应用程序。
通过 Docker 工具窗口,开发者可以连接到本地运行的 Docker 机器,管理图像、容器和 Docker Compose 服务。多语言支持是 IntelliJ IDEA 的一大亮点,它不仅支持 Java,还支持 Groovy、Kotlin、Scala、JavaScript、TypeScript 和 SQL 等其他语言。IDE 提供了顶级框架的一流支持,包括 Spring、Java EE、Grails、Play、Android、GWT、Vaadin、Thymeleaf、React、AngularJS 等,帮助开发者高效完成多语言项目的开发。
IntelliJ IDEA 以其强大的功能、丰富的插件生态系统和多语言支持,成为一款功能全面、易于使用的集成开发环境,适合各类开发者在 Java 和多语言项目开发中使用。
Ⅱ Murmur哈希算法
说到哈希算法,可能大部分人都会不自觉得想到 md 和 sha 系列,在这之前,我就是这样的,因为他们意味着流行安全和稳定。但是,最近我知道了一款另类的流行的哈希函数, 这款哈希函数广泛应用于分布式系统-Hadoop/Lucence等等,原因就是因为它速度快而且散列效果好 ,这个哈希算法就是 MurmurHash。
哈希系列比较流行的有三个系列,分别是 MD/SHA 和 MAC 系列,但是这些系列都是比较安全,虽然 MD5 和 SHA-1 已经被王小云教授碰撞了,但是相对我们平时使用的直接简单求模这种还是比较安全的,相对安全带来的负面效果就是 计算量还是挺大的,而且不保证哈希结果的均匀 。而在分布式环境下,为了资源的合理利用,我们需要的更多是均匀,因为是内部散列的作用,所以哈希安全我们并不那么在乎,所以在这种情境下,2008 才被发明的 MurmurHash 成为了分布式中的宠儿,深受 Google 系的喜爱。
MurmurHash 当前最新的版本是 MurmurHash3,它能够产生出32-bit或128-bit哈希值。除了我们能够猜到的不再使用的 mmh1 以及 还在使用的 mmh2 之外,还有好些变种,不过都是针对平台优化的。
Murmur哈希的算法确实比较简单,它的计算过程其实就是它的名字,MUltiply and Rotate,因为它在哈希的过程要经过多次MUltiply and Rotate,所以就叫 MurMur 了。
算法原理可参考维基网络: https://zh.wikipedia.org/wiki/Murmur%E5%93%88%E5%B8%8C
Scala API自身是有MurmurHash算法的实现的( scala.util.hashing.MurmurHash3 ),返回值是int,32位。
spark也广泛采用了Murmur哈希算法,可以看一个在sparksql中的例子,在TreeNode类中有:
之所以调用 proctHash 方法是因为TreeNode继承自scala的 Proct 特质(有兴趣的同学可以通过反编译查看到,scala 的Case class类实现了scala.Proct和scala.Serializable接口(Proct和Serializable都是Traits)),而且有很多case class 类继承TreeNode类。
参考:
https://liqiang.io/post/murmurhash-introction
https://leibnizhu.github.io/2017/01/19/Scala%E5%AE%9E%E7%8E%B064%E4%BD%8D%E7%9A%84MurmurHash%E5%87%BD%E6%95%B0/index.html