JavaScript中全域變數、函數內變數以及常量運算式的效率測試_javascript技巧

來源:互聯網
上載者:User

<html> <body> <script type="text/javascript"> var r, s = "this is a very very looooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooong string", x = /^\s+|\s+$/g; document.writeln("字串測試"); (function(){ document.write("全域->全域:"); var t = new Date(); for(var i = 0; i < 3000000; i++){ r = s; } document.write(new Date() - t); document.writeln(""); })(); (function(){ document.write("全域->本地:"); var s = window.s; var t = new Date(); for(var i = 0; i < 3000000; i++){ r = s; } document.write(new Date() - t); document.writeln(""); })(); (function(){ document.write("常量->本地:"); var r; var t = new Date(); for(var i = 0; i < 3000000; i++){ r = "this is a very very looooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooong string"; } document.write(new Date() - t); document.writeln(""); })(); (function(){ document.write("屬性->本地:"); var r; var s = { 0: window.s }; var t = new Date(); for(var i = 0; i < 3000000; i++){ r = s[0]; } document.write(new Date() - t); document.writeln(""); })(); (function(){ document.write("本地->本地:"); var r; var s = window.s; var t = new Date(); for(var i = 0; i < 3000000; i++){ r = s; } document.write(new Date() - t); document.writeln(""); })(); document.writeln("Regex測試"); (function(){ document.write("全域->全域:"); var t = new Date(); for(var i = 0; i < 3000000; i++){ r = x; } document.write(new Date() - t); document.writeln(""); })(); (function(){ document.write("全域->本地:"); var x = window.x; var t = new Date(); for(var i = 0; i < 3000000; i++){ r = x; } document.write(new Date() - t); document.writeln(""); })(); (function(){ document.write("常量->本地:"); var r; var t = new Date(); for(var i = 0; i < 3000000; i++){ r = /^\s+|\s+$/g; } document.write(new Date() - t); document.writeln(""); })(); (function(){ document.write("屬性->本地:"); var r; var x = { 0: window.x }; var t = new Date(); for(var i = 0; i < 3000000; i++){ r = x[0]; } document.write(new Date() - t); document.writeln(""); })(); (function(){ document.write("本地->本地:"); var r; var x = window.x; var t = new Date(); for(var i = 0; i < 3000000; i++){ r = x; } document.write(new Date() - t); document.writeln(""); })(); </script> </body> </html>
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]

注意:在IE中進行這個測試時需要先改變IE的"最大指令碼步數":
[HKEY_CURRENT_USER\Software\Microsoft\Internet Explorer\Styles]
"MaxScriptStatements"=dword:ffffffff
這麼看的話使用函數內的本地變數時效率要比用全域變數或者常量運算式高出許多。而屬性的效率就糟得很恐怖了,在Firefox和Safari中居然比利用全域變數還慢上好多倍。
直接用字串常量要比利用全域變數快,但建立Regex就比起用全域變數要慢上很多了。
觀察數字還可以發現:在Google Chrome、Opera和IE中,用屬性和利用全域變數相差不大(Opera的表現也許是其記憶體回收機製造成的),從這個現象上看的話,這三種瀏覽器中所謂的全域變數有可能根本就是全域對象的屬性。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.