关键词的内联(Symbol)方法使用递归调用来获取一个有效的关键词实例。我认为它可以重写为'for循环'以减少方法调用开销。
。所以,我开发了这个补丁并进行了一些简单的基准测试。在执行'ant jar'后,运行以下命令行三次:
java -Xms64m -Xmx64m -cp test:clojure.jar clojure.main -e "(time (dotimes (link: n 10000000) (keyword (str n))))"
修改前
"执行时间:27343.827 毫秒"
"执行时间:26172.653 毫秒"
"执行时间:25673.764 毫秒"
修改后
"执行时间:24884.142 毫秒"
"执行时间:23933.423 毫秒"
"执行时间:25382.783 毫秒"
"执行时间:24884.142 毫秒"
看起来补丁使关键词的内联略快一些。
补丁已附上并进行了测试。
谢谢。
附言:我已经签署了贡献者协议,我的邮箱是[email protected]。