我正在尝试编写一个可以测量另一个函数执行时间的函数:
export class Profiler {
public measureSyncFunc(fn: () => any): Promise<number> {
return new Promise<number>((resolve, reject) => {
let elapsed = 0;
let intervalId = window.setInterval(() => {
elapsed += 1; // this is never called
}, 1);
this.execFunc(fn)
.then((result: any) => {
window.clearInterval(intervalId);
resolve(elapsed);
});
});
}
private execFunc(fn: () => any): Promise<any> {
return new Promise<any>((resolve, reject) => {
resolve(fn());
});
}
}
然后我像这样使用它:
let array = generateRandomArray(100000);
instance.measureSyncFunc(bubbleSort(array))
.then((elapsed: number) => {
console.log(`end session: ${elapsed} seconds`);
resolve();
});
bubbleSort函数是同步的,需要几秒钟才能完成。在这里查看代码:
控制台中的结果是“结束会话:0秒”,因为从未调用间隔回调。
你知道我怎么称呼它吗?非常感谢你们 !
如果您要衡量的功能始终是同步的,则实际上不需要涉及承诺。
由于要测试的函数需要参数,因此最好将其包装在箭头函数中,以便能够在其他上下文中调用它,而不必自己管理它的参数。
像这样简单的事情就可以了。
function measure(fn: () => void): number {
let start = performance.now();
fn();
return performance.now() - start;
}
function longRunningFunction(n: number) {
for (let i = 0; i < n; i++) {
console.log(i);
}
}
let duration = measure(() => {
longRunningFunction(100);
});
console.log(`took ${duration} ms`);
如果您想测量花费一个异步函数(如果它返回一个promise)来解决的时间,则可以轻松地将代码更改为如下所示:
function measurePromise(fn: () => Promise<any>): Promise<number> {
let onPromiseDone = () => performance.now() - start;
let start = performance.now();
return fn().then(onPromiseDone, onPromiseDone);
}
function longPromise(delay: number) {
return new Promise<string>((resolve) => {
setTimeout(() => {
resolve('Done');
}, delay);
});
}
measurePromise(() => longPromise(300))
.then((duration) => {
console.log(`promise took ${duration} ms`);
});
注意:此解决方案使用ES6 Promise,如果您使用其他东西,则可能需要对其进行调整,但逻辑应相同。
您可以在此处在操场上看到两个示例。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句