[TS LeetCode 筆記] 2637. Promise Time Limit

閱讀時間約 5 分鐘

原題目:

Given an asynchronous function fn and a time t in milliseconds, return a new time limited version of the input function. fn takes arguments provided to the time limited function.

The time limited function should follow these rules:

  • If the fn completes within the time limit of t milliseconds, the time limited function should resolve with the result.
  • If the execution of the fn exceeds the time limit, the time limited function should reject with the string "Time Limit Exceeded".

題目知識點:

  1. 異步編程概念: 考題要求理解和應用異步函數,這意味著你需要知道如何處理非同步操作,以確保代碼不會在等待操作完成時被阻塞。
  2. Promise 使用: 你需要了解 JavaScript 中的 Promise 如何工作,包括如何創建、解析、拒絕和處理 Promise。在這個題目中,你需要處理成功的 Promise 和被拒絕的 Promise。
  3. 計時器函數: 你需要了解 JavaScript 中的 setTimeoutclearTimeout 函數,以設定和取消計時器。這是用來確保異步操作在指定時間內完成的重要工具。
  4. 函數參數和引數: 題目要求你將一個函數 fn 以及時間限制 t 作為參數,然後使用這些參數來創建新的時間限制版本的函數。你需要了解如何在函數中處理這些引數。
  5. 錯誤處理: 這個題目要求你處理可能出現的錯誤,並返回指定的錯誤消息。你需要知道如何使用 try...catch 來處理可能的錯誤情況。

總結來說,這個題目主要測試你對異步編程、Promise、計時器函數和函數引數的理解和應用,以及你的錯誤處理能力。

先備知識:

  • setTimeout 和 clearTimeout: setTimeout 是 JavaScript 中的函數,它允許我們在一定的時間後執行指定的程式碼。clearTimeout 用於取消計時器。
  • Promise.race: Promise.race 是 Promise 的一個方法,它可以同時監控多個 Promise,並在其中任何一個 Promise 完成時返回該 Promise 的結果。

應用情境:

這段程式碼適用於網頁頁面開發中的各種場景,以下是一些實際例子:

  • 網頁請求超時控制: 在網頁應用程式中,當我們向伺服器發送網絡請求時,我們希望確保請求不會花費太長時間。這段程式碼可以用來設定一個時間限制,如果網絡請求在指定時間內未完成,它將立即返回一個錯誤,以確保用戶體驗不會受到阻礙。
  • 前端性能優化: 在前端開發中,我們常常需要執行一些計算或操作,以提高網頁性能。這段程式碼可用於設定最大執行時間,以確保這些操作不會對網頁的反應時間產生負面影響。
  • 遊戲開發: 在線遊戲或網頁遊戲中,我們可能需要控制特定遊戲事件的執行時間。使用這段程式碼,我們可以確保這些事件不會長時間阻塞遊戲的進行。

結論:

這段程式碼提供了一個有效的方法,用於在異步操作中添加時間限制,以確保它們不會花費過長的時間。它使用了 JavaScript 中的 Promise、setTimeout 函數和 Promise.race 方法,這些都是處理異步操作時的重要工具。當需要確保操作在合理時間內完成時,這段程式碼是一個有用的工具,它提高了應用程式的可靠性和用戶體驗。

解答

type Fn = (...params: any[]) => Promise<any>;

/**
 * @param {Function} fn
 * @param {number} t
 * @return {Function}
 */
function timeLimit(fn: Fn, t: number): Fn {
   
    return async function(...args) {
        let timer: ReturnType<typeof setTimeout>;
        const timePromise: Promise<void> = new Promise<void> ((_, reject) => {
            timer = setTimeout(() => reject('Time Limit Exceeded'), t);
        })
        try {
            const result = await Promise.race([fn(...args), timePromise]);
            return result;
        } finally {
            clearTimeout(timer);
        }
    }
};


2會員
8內容數
"TypeScript LeetCode" 以 TypeScript 為工具,深入解析 LeetCode 上的算法和資料結構問題,提供清晰解釋和程式碼示範,幫助您精進 TypeScript 技能,解決挑戰性問題,無論您的程式開發水平如何。讓我們一同鑽研、提升,迎接算法挑戰,成長技術專長!,快速提高您的技能水平
留言0
查看全部
發表第一個留言支持創作者!
毛怪的沙龍 的其他內容
[Leetcode 筆記] TypeScript 2715. Timeout Cancellation 了解和有效使用 clearTimeout 和 setTimeout 可以提高JavaScript程序的效率和響應性。
分享今年29歲的我,離職之後開始探索自己的過程。
[Leetcode 筆記] TypeScript 2715. Timeout Cancellation 了解和有效使用 clearTimeout 和 setTimeout 可以提高JavaScript程序的效率和響應性。
分享今年29歲的我,離職之後開始探索自己的過程。
你可能也想看
Google News 追蹤
Thumbnail
這個秋,Chill 嗨嗨!穿搭美美去賞楓,裝備款款去露營⋯⋯你的秋天怎麼過?秋日 To Do List 等你分享! 秋季全站徵文,我們準備了五個創作主題,參賽還有機會獲得「火烤兩用鍋」,一起來看看如何參加吧~
Thumbnail
題目摘要 給定一個整數陣列 `prices`,其中 `prices[i]` 代表第 `i` 天的股票價格。在每一天,你可以決定買入和/或賣出股票。然而,你同一時間只能擁有至多一股股票。你可以在同一天內買入然後立刻賣出股票。找出並返回你可以實現的最大利潤。
Thumbnail
題目摘要 給定一個陣列 prices,其中 prices[i] 代表第 i 天的股票價格。你希望透過在某一天購買一股股票,並在未來的某一天賣出它,以最大化你的利潤。如果無法獲得任何利潤,則返回 0。
Thumbnail
題目摘要: 在這篇文章中,我們將討論如何使用摩爾投票算法找出一個陣列中的「主要元素」。主要元素指的是在陣列中出現次數超過一半的元素,並且我們可以確定它一定存在於陣列中。這個算法的核心思想和應用將在本文中被詳細介紹。 題目知識點: 主要元素的定義和重要性。 摩爾投票算法的工作原理和優點。 先備知識
Thumbnail
重要知識點: 1. TypeScript 全局擴展,使所有陣列都能使用 groupBy 方法。 2. 利用泛型創建彈性函數,提高代碼可重用性。 3. 迭代陣列中的元素,實現遍歷和處理功能。 4. 物件的鍵值對操作,用於建立以函數輸出為鍵的物件。
Thumbnail
隨著科技的進步和遠程工作的興起,通訊方式正在經歷劇變。然而,這也讓許多人對於傳統的電話禮儀感到困惑。美國禮儀專家Lizzie Post針對這一問題,提出了六大電話禮儀建議,幫助我們在新的通訊環境下保持專業和禮貌。
Thumbnail
上週的雙11大家有買東西嗎? 去年雙11購入了tokuto的眼部按摩器TS-183使用滿一年心得分享給大家,希望能幫助跟我一樣眼睛容易酸澀又找不到相關心得文的人~
2021年底前價格應該會在 112-120之間移動
Thumbnail
電動汽車龍頭 Tesla,正式發布了他們在今年第二季的財報,交出了非常亮眼的成績,無論是在營收,或者是獲利上,都超過了市場上的分析師預期,也讓盤後特斯拉的股價上漲了 1%。當然,作為市場上最熱門的股票之一,特斯拉的營運狀況是非常多人關注的焦點,所以就讓科技巨頭解碼來帶大家看特斯拉最新一季的財報重點。
Thumbnail
這個秋,Chill 嗨嗨!穿搭美美去賞楓,裝備款款去露營⋯⋯你的秋天怎麼過?秋日 To Do List 等你分享! 秋季全站徵文,我們準備了五個創作主題,參賽還有機會獲得「火烤兩用鍋」,一起來看看如何參加吧~
Thumbnail
題目摘要 給定一個整數陣列 `prices`,其中 `prices[i]` 代表第 `i` 天的股票價格。在每一天,你可以決定買入和/或賣出股票。然而,你同一時間只能擁有至多一股股票。你可以在同一天內買入然後立刻賣出股票。找出並返回你可以實現的最大利潤。
Thumbnail
題目摘要 給定一個陣列 prices,其中 prices[i] 代表第 i 天的股票價格。你希望透過在某一天購買一股股票,並在未來的某一天賣出它,以最大化你的利潤。如果無法獲得任何利潤,則返回 0。
Thumbnail
題目摘要: 在這篇文章中,我們將討論如何使用摩爾投票算法找出一個陣列中的「主要元素」。主要元素指的是在陣列中出現次數超過一半的元素,並且我們可以確定它一定存在於陣列中。這個算法的核心思想和應用將在本文中被詳細介紹。 題目知識點: 主要元素的定義和重要性。 摩爾投票算法的工作原理和優點。 先備知識
Thumbnail
重要知識點: 1. TypeScript 全局擴展,使所有陣列都能使用 groupBy 方法。 2. 利用泛型創建彈性函數,提高代碼可重用性。 3. 迭代陣列中的元素,實現遍歷和處理功能。 4. 物件的鍵值對操作,用於建立以函數輸出為鍵的物件。
Thumbnail
隨著科技的進步和遠程工作的興起,通訊方式正在經歷劇變。然而,這也讓許多人對於傳統的電話禮儀感到困惑。美國禮儀專家Lizzie Post針對這一問題,提出了六大電話禮儀建議,幫助我們在新的通訊環境下保持專業和禮貌。
Thumbnail
上週的雙11大家有買東西嗎? 去年雙11購入了tokuto的眼部按摩器TS-183使用滿一年心得分享給大家,希望能幫助跟我一樣眼睛容易酸澀又找不到相關心得文的人~
2021年底前價格應該會在 112-120之間移動
Thumbnail
電動汽車龍頭 Tesla,正式發布了他們在今年第二季的財報,交出了非常亮眼的成績,無論是在營收,或者是獲利上,都超過了市場上的分析師預期,也讓盤後特斯拉的股價上漲了 1%。當然,作為市場上最熱門的股票之一,特斯拉的營運狀況是非常多人關注的焦點,所以就讓科技巨頭解碼來帶大家看特斯拉最新一季的財報重點。