日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

使用prototype特性编程中的效率问题

發布時間:2025/3/15 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 使用prototype特性编程中的效率问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

??? 前幾天有位網友詢問了我一個問題,主要是關于JavaScript的prototype特性的效率。因為作為一個如此強大并且靈活的東西,難免會讓人覺得效率上可能有較大的損失。但是實際上prototype特性的效率怎么樣呢?我們下面來詳細說說這個問題。

??? 之前我曾經寫過兩篇隨筆介紹JavaScript語言的prototype特性,"JScript中的prototype(原型)屬性研究(1)"和"JScript中的prototype(原型)屬性研究(2)"。第一篇非常基礎,只是說明了prototype的用途和用法,第二篇基本上算是深入說明了JavaScript的prototype的實現機制,不過當時沒有對prototype的效率作任何討論,真是遺憾。

??? 先看一個prototype屬性和方法效率比較的示例:

<html>
<head>
????
<title>Prototype?Performancetitle>
????
<meta?name="author"?content="birdshome@cnblogs"?/>
</head>
<body>
????
<script?language="javascript">
????
function?fnMethod(i)
????
{
????????
var?tmp?=?i+3;
????}


????Object.prototype.i?
=?0;
????Object.prototype.fnMethod?
=?function()
????
{
????????
var?tmp?=?this.i+3;
????}

????
</script>
????
<script?language="javascript">
????
function?Test_fnMethod()
????
{
????????
var?dt?=?new?Date();
????????
for?(?var?i=0?;?i?<?100?;?++i?)
????????
{
????????????
for?(?var?j=0?;?j?<?10000?;?++j?)
????????????
{
????????????????fnMethod(i);
????????????}

????????}

????????alert(
new?Date()?-?dt);
????}

????
????
function?Test_prototype_fnMethod()
????
{
????????
var?obj?=?{};
????????
var?dt?=?new?Date();
????????
for?(?var?i=0?;?i?<?100?;?++i?)
????????
{
????????????
for?(?var?j=0?;?j?<?10000?;?++j?)
????????????
{
????????????????obj.fnMethod();
????????????}

????????}

????????alert(
new?Date()?-?dt);
????}
????
????
</script>
????
<button?onclick="Test_fnMethod()">
????????fnMethod
</button>
????
<button?onclick="Test_prototype_fnMethod()">
????????prototype.fnMethod
</button>
</body>
</html>

??? 上面示例的測試結果分別是:4,046ms和4,719ms!(P4 2.4G IE6 SV1 en)。普通方法和原型方法之間的每一次調用效率差別為:663/1,000,000 毫秒(實際上是一次原型屬性和一次原型方法調用共同消耗的時間周期,var tmp = this.i+3;)。

??? 這個結果看起來挺不錯的,似乎使用prototype也就不存在什么效率問題了。但是如果我們在一個頁面中使用了大量的自定義對象,同時對象又和表現層的HTML元素對象建立了較密切的引用聯系后,我們常常會覺的整個頁面對腳本的執行都慢了下來,這是怎么回事呢?是誰在吞噬CPU資源?!

??? 這是由于JavaScript這種腳本語言不需要用戶管理內存使用,所以它自身需要管理自己的資源開銷,也就是說JavaScript的運行引擎要負責GC。但是JavaScript使用的"簡單標記清除"算法,對于復雜的環狀引用的標記不是很有效(我在IE的Memory Leak相關文章中有詳細介紹),加之IE對于DHTML DOM象生存期策略等問題。當頁面內的DOM和腳本對象越來越多,并不能及時釋放后,IE的腳本執行效率就非常明顯的降下來了。嚴重到我們剛打開IE時很簡單的一個腳本操作,都會變得很緩慢,一執行CPU就會串到一個很高的占用峰值。

轉載于:https://www.cnblogs.com/birdshome/archive/2005/08/01/205128.html

總結

以上是生活随笔為你收集整理的使用prototype特性编程中的效率问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。