数组求和的两种方式与性能比较
Posted 莫弃i
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数组求和的两种方式与性能比较相关的知识,希望对你有一定的参考价值。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>无标题文档</title> <script> var arr = [1,2,3,4,5]; Array.prototype.sum = function (){ return eval(this.join(‘+‘)); } console.time(‘a‘); console.log(arr.sum()); console.timeEnd(‘a‘); Array.prototype.sum2 = function (){ var len = this.length; var num = 0; for( var i=0;i <len; i++ ){ num += this[i]; } return num; } console.time(‘b‘); console.log(arr.sum2()); console.timeEnd(‘b‘); </script> </head> <body> </body> </html>
eval的性能比for的差很多,因为eval会把字符串转换成javascript语句,然后在执行。转换的过程中是消耗性能最大的地方。
以上是关于数组求和的两种方式与性能比较的主要内容,如果未能解决你的问题,请参考以下文章
Java数据结构及算法实战系列003:程序性能的两种表示方式