欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js 函數(shù)性能比較方法

 更新時(shí)間:2020年08月24日 15:17:02   作者:quanwuhui  
在學(xué)習(xí)js過程中,經(jīng)常會(huì)遇到同樣一個(gè)功能點(diǎn) 這樣實(shí)現(xiàn)也可以,那樣實(shí)現(xiàn)也可以。但是哪個(gè)方式最優(yōu)呢

在學(xué)習(xí)js過程中,經(jīng)常會(huì)遇到同樣一個(gè)功能點(diǎn) 這樣實(shí)現(xiàn)也可以,那樣實(shí)現(xiàn)也可以。但是哪個(gè)方式最優(yōu)呢?自己寫了一個(gè)簡短的proferencesCompare 函數(shù)。代碼如下:

/**
	 * 函數(shù)性能比較
	 * @param fns 要比較的函數(shù)數(shù)組
	 * @args 每個(gè)要比較函數(shù)在執(zhí)行的時(shí)候傳入的參數(shù),可以是數(shù)組,或者 被調(diào)用后 返回?cái)?shù)組類型
	 * @repeatCount 每個(gè)函數(shù)重復(fù)執(zhí)行的次數(shù),多次執(zhí)行 拉開差距。默認(rèn)值10000
	 * 
	 * @return [{runTime:執(zhí)行repeatCount次總時(shí)間,repeatCount:重復(fù)執(zhí)行次數(shù),name:函數(shù)名稱,chrome是函數(shù)名,IE由于不支持funciton.name,所以默認(rèn) fn+函數(shù)在fns中index}]
	 * */
	function proferencesCompare(fns, args, repeatCount) {
		var tmpArgs, tmpFns;
		var result = [];
		var starTime, endTime;
		var i = 0;
		var repeatCount = repeatCount || 10000;
		var isFunction = false;
		if(fns === undefined) {
			throw Error('Must have the compare funciton');
		}
 
		var typeName = typeof args;
 
		//檢測傳入的args是否能夠返回array類型數(shù)據(jù)
		if(typeName === 'function') {
			tmpArgs = args();
			isFunction = true;
		}
 
		if(typeName === 'number') {
			tmpArgs = [];
			repeatCount = args;
		}
 
		//檢測args 是否為 array
		if(Object.prototype.toString.call(tmpArgs) !== '[object Array]') {
			throw Error('The test args is must a array or a function which return the array');
		}
 
		var len = fns.length;
		for(; i < len; i++) {
			var fnName = fns[i].name || "fn" + i;
			starTime = Date.now();
			console.time(fnName);
			for(var j = 0; j < repeatCount; j++) {
				if(isFunction && (i !== 0 || j !== 0)) {
					//如果args是函數(shù),并且循環(huán)是第一次進(jìn)入,則不需要再執(zhí)行一次。前面做args檢測時(shí)已經(jīng)執(zhí)行過一次
					tmpArgs = args();
				}
				fns[i].apply(this, tmpArgs);
			}
			console.timeEnd(fnName);
			endTime = Date.now();
			result.push({ runTime: endTime - starTime, repeatCount: repeatCount, name: fnName });
		}
		return result;
	}

使用例子如下:

var fn1 = function() {
		var a;
		return !a;
	}
 
var fn2 = function() {
		var a;
		return a === undefined;
	}
 
var fn3 = function() {
		var a;
		return a == undefined;
	}
 
var result = proferencesCompare([fn1, fn2, fn3, fn3, fn2, fn1], 1000000000);

這個(gè)例子主要比較 對(duì)于函數(shù)中 判斷對(duì)象是否為undefined 的幾種實(shí)現(xiàn)方式的性能比較。

chrome:

結(jié)果顯示 其實(shí)性能差不多。

下面是其他同學(xué)的補(bǔ)充

快速比較代碼執(zhí)行效率的方法

測試效率可以使用Stopwatch :

Stopwatch sw = new Stopwatch();
sw.Start();//寫在要執(zhí)行的代碼前面

sw.Stop();//寫在要執(zhí)行的代碼結(jié)尾
sw.Elapsed//得到代碼執(zhí)行時(shí)間

核心函數(shù)

int[] array = { 15,20,10,3,5};
Stopwatch sw = new Stopwatch();
sw.Start();

for (int i = 0; i < array.Length - 1; i++) {
  for (int j = i + 1; j < array.Length; j++) {
    if (array[i] > array[j]) {

      int temp = array[i];
      array[i] = array[j];
      array[j] = temp;
    }
  }
}
sw.Stop();
Console.WriteLine(sw.Elapsed);

到此這篇關(guān)于js 函數(shù)性能比較方法的文章就介紹到這了,更多相關(guān)js 函數(shù)性能內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JS幻想 讀取二進(jìn)制文件

    JS幻想 讀取二進(jìn)制文件

    如果說讓JavaScript讀取站點(diǎn)上一文本文件,那不過是個(gè)再簡單不了的事了;但若說要換成一個(gè)二進(jìn)制的文件,并且是完全靜態(tài)的讀取,那似乎有點(diǎn)天方夜譚了。
    2009-04-04
  • 淺談JavaScript之事件綁定

    淺談JavaScript之事件綁定

    關(guān)于 JavaScript 的事件綁定在網(wǎng)上已經(jīng)有不少相關(guān)的資料了,今天這篇文章也是在被同事問及的時(shí)候才順便把它記錄下來,算是 JavaScript 事件綁定中的一個(gè)小技巧,如果能在工作中善加利用,會(huì)有出其不意的效果
    2013-07-07
  • JS實(shí)現(xiàn)禁止用戶使用Ctrl+鼠標(biāo)滾輪縮放網(wǎng)頁的方法

    JS實(shí)現(xiàn)禁止用戶使用Ctrl+鼠標(biāo)滾輪縮放網(wǎng)頁的方法

    這篇文章主要介紹了JS實(shí)現(xiàn)禁止用戶使用Ctrl+鼠標(biāo)滾輪縮放網(wǎng)頁的方法,涉及javascript頁面元素與事件相關(guān)操作技巧,需要的朋友可以參考下
    2017-04-04
  • Dropzone.js實(shí)現(xiàn)文件拖拽上傳功能(附源碼下載)

    Dropzone.js實(shí)現(xiàn)文件拖拽上傳功能(附源碼下載)

    dropzone.js是重量輕的JavaScript庫,將HTML元素設(shè)置為一個(gè)降落區(qū),并通過Ajax文件被上傳到服務(wù)器。本文給大家詳細(xì)介紹Dropzone.js實(shí)現(xiàn)文件拖拽上傳功能,需要的朋友參考下吧
    2016-11-11
  • js利用cookie實(shí)現(xiàn)記住用戶頁面操作

    js利用cookie實(shí)現(xiàn)記住用戶頁面操作

    這篇文章主要給大家介紹了關(guān)于js利用cookie實(shí)現(xiàn)記住用戶頁面操作的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • JavaScript函數(shù)調(diào)用經(jīng)典實(shí)例代碼

    JavaScript函數(shù)調(diào)用經(jīng)典實(shí)例代碼

    JavaScript提供了4種函數(shù)調(diào)用,一般形式的函數(shù)調(diào)用、作為對(duì)象的方法調(diào)用、使用 call 和 apply 動(dòng)態(tài)調(diào)用、使用 new 間接調(diào)用,下面這篇文章主要給大家介紹了關(guān)于JavaScript函數(shù)調(diào)用的相關(guān)資料,需要的朋友可以參考下
    2021-12-12
  • javascript一些實(shí)用技巧小結(jié)

    javascript一些實(shí)用技巧小結(jié)

    javascript一些實(shí)用技巧小結(jié),學(xué)習(xí)js的朋友可以看下。
    2011-03-03
  • JS實(shí)現(xiàn)霓虹燈文字效果的方法

    JS實(shí)現(xiàn)霓虹燈文字效果的方法

    這篇文章主要介紹了JS實(shí)現(xiàn)霓虹燈文字效果的方法,涉及javascript遍歷字符串及頁面樣式的動(dòng)態(tài)操作技巧,效果非常炫目華麗,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-08-08
  • 微信小程序生成分享海報(bào)方法(附帶二維碼生成)

    微信小程序生成分享海報(bào)方法(附帶二維碼生成)

    這篇文章主要介紹了微信小程序生成分享海報(bào)方法(附帶二維碼生成),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • 通過js動(dòng)態(tài)創(chuàng)建標(biāo)簽,并設(shè)置屬性方法

    通過js動(dòng)態(tài)創(chuàng)建標(biāo)簽,并設(shè)置屬性方法

    下面小編就為大家分享一篇通過js動(dòng)態(tài)創(chuàng)建標(biāo)簽,并設(shè)置屬性方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02

最新評(píng)論