“高性能javascript” 这本书中提到了一个“查找表”的概念,建议在有大量离散值要测试时,if-else 和 switch 都比使用查找表慢很多,依据是运行了5万次后的比较结果 例如写一个测试函数,根据传入的参数,返回结果值 switch 的写法
查找表的写法
测试
我好奇这两种写法的性能差距有多少,就测试了一下 代码 var index = 0; console.time('test'); for (var i = 50000; i >= 0; i--)
{ index = index == 10 ? 0 : index ;
search(index++); } console.timeEnd('test'); 分别使用上面两个函数进行测试,执行5万次 switch写法的5次结果分别为: 1.25ms 0.91ms 1.22ms 1.31ms 0.89ms 查找表写法的5次结果分别为: 1.86ms 1.43ms 3.13ms 1.08ms 1.05ms 很明显是switch的写法更快一点,不知道为什么结果和书中不符
总结
个人感觉没啥必要细究哪种语法性能更好,对系统整体性能几乎没有影响 但这个查找表的方式我比较喜欢,给了我一个新的思路
平时写代码时主要用 if-else,习惯了,没想过用别的方法 查找表的方式有两个明显的优点: (1)代码清晰 比switch和if-else简单很多 (2)便于后期维护 当以后想增加或者减少条件时,只需要修改下表中条件值就好了 通过这个小实验,增加了两个经验: (1)不要完全依赖书中说法,多动手测试 (2)对于习惯了的做法也要有点思考,看是否有更合适的做法