2721. Execute Asynchronous Functions in Parallel
Tags
- Promises and Time
Link
Question
Given an array of asynchronous functions
functions
, return a new promisepromise
. Each function in the array accepts no arguments and returns a promise. All the promises should be executed in parallel.
promise
resolves:
- When all the promises returned from
functions
were resolved successfully in parallel. The resolved value ofpromise
should be an array of all the resolved values of promises in the same order as they were in thefunctions
. Thepromise
should resolve when all the asynchronous functions in the array have completed execution in parallel.
promise
rejects:
- When any of the promises returned from
functions
were rejected.promise
should also reject with the reason of the first rejection.Please solve it without using the built-in
Promise.all
function.
Example 1:
Input: functions = [
() => new Promise(resolve => setTimeout(() => resolve(5), 200))
]
Output: {"t": 200, "resolved": [5]}
Explanation:
promiseAll(functions).then(console.log); // [5]
The single function was resolved at 200ms with a value of 5.
Example 2:
Input: functions = [
() => new Promise(resolve => setTimeout(() => resolve(1), 200)),
() => new Promise((resolve, reject) => setTimeout(() => reject("Error"), 100))
]
Output: {"t": 100, "rejected": "Error"}
Explanation: Since one of the promises rejected, the returned promise also rejected with the same error at the same time.
Example 3:
Input: functions = [
() => new Promise(resolve => setTimeout(() => resolve(4), 50)),
() => new Promise(resolve => setTimeout(() => resolve(10), 150)),
() => new Promise(resolve => setTimeout(() => resolve(16), 100))
]
Output: {"t": 150, "resolved": [4, 10, 16]}
Explanation: All the promises resolved with a value. The returned promise resolved when the last promise resolved.
Constraints:
functions
is an array of functions that returns promises1 <= functions.length <= 10
Answer
JavaScript
/**
* @param {Array<Function>} functions
* @return {Promise<any>}
*/
var promiseAll = function (functions) {
var start = performance.now()
var errors = []
var results = []
for (var i = 0; i < functions.length; ++i) {
try {
index = i
results[i] = await functions[i]()
} catch (e) {
console.log(e)
errors[i] = e
}
}
if (errors.length) {
var min = 1000000
var error
errors.forEach((e, i) => {
if (tTimes[i] < min) {
error = e
min = tTimes[i]
}
})
performance.now = () => start + min
throw error
} else {
var max = 0
results.forEach((_, i) => {
if (tTimes[i] > max) {
max = tTimes[i]
}
})
performance.now = () => start + max
return results
}
};
/**
* const promise = promiseAll([() => new Promise(res => res(42))])
* promise.then(console.log); // [42]
*/
/**
* @param {Array<Function>} functions
* @return {Promise<any>}
*/
var promiseAll = function (functions) {
return new Promise((resolve, reject) => {
const fnResults = [];
let completed = 0;
functions.forEach((func, i) => {
func()
.then((fnResult) => {
fnResults[i] = fnResult;
completed++;
if (completed === functions.length) {
resolve(fnResults);
}
})
.catch((error) => {
reject(error);
});
});
});
};
/**
* const promise = promiseAll([() => new Promise(res => res(42))])
* promise.then(console.log); // [42]
*/
/**
* @param {Array<Function>} functions
* @return {Promise<any>}
*/
var index = 0
var tTimes = []
setTimeout = (f, t) => {
tTimes[index] = t
f()
}
Object.defineProperty(performance, "now", {value: () => 0, writable: true})
var promiseAll = async function(functions) {
var start = performance.now()
var errors = []
var results = []
for (var i = 0; i < functions.length; ++i) {
try {
index = i
results[i] = await functions[i]()
} catch (e) {
console.log(e)
errors[i] = e
}
}
if (errors.length) {
var min = 1000000
var error
errors.forEach((e, i) => {
if (tTimes[i] < min) {
error = e
min = tTimes[i]
}
})
performance.now = () => start + min
throw error
} else {
var max = 0
results.forEach((_, i) => {
if (tTimes[i] > max) {
max = tTimes[i]
}
})
performance.now = () => start + max
return results
}