如何在 VS Code 中調試 LeetCode 程式碼?

  • 2019 年 12 月 30 日
  • 筆記

摘要: 面試刷題指南。

Fundebug經授權轉載,版權歸原作者所有。

近期收到不少小夥伴的求助,希望知道如何在 VS Code 中調試 LeetCode 程式碼。通常來說,為了調試本地程式碼,我們需要安裝相關的語言支援插件。本文中,我們就以調試 LeetCode Java 程式碼為例,給大家介紹本地調試 LeetCode 程式碼的常用套路。

想要了解如何在 VS Code 中刷題的小夥伴,可以移步:LeetCode for VS Code: 春招 Offer 收割利器

準備工作

首先確保系統內安裝了 JDK,相關教程有很多,此處就不贅述了。

之後我們需要確保在 VS Code 中安裝了下列插件:

1. LeetCode

用來生成題目,提交答案。

2. Language Support for Java(TM) by Red Hat

提供智慧提示等語言相關的功能。

3. Debugger for Java,Java

調試器。

安裝完成之後,VS Code 的插件管理欄中,就可以看到這三個插件了:

如果在打開 Java 文件後,VS Code 提示找不到 JDK,請檢查一下相關配置是否正確

編寫調試程式碼:

我們就拿第 20 題:有效的括弧作為例子。

在作答過程中,可能會看到編輯器里出現一些紅線。不要擔心,這表明 Language Support for Java 插件正在起作用。通常這意味著你的程式碼存在語法錯誤,下面的例子展示的錯誤原因是用到了依賴包但沒有 import 到當前文件當中。我們可以利用 Quick Fix 功能進行修復:

將依賴包導入時為了確保文件能夠被正確編譯。LeetCode 在檢查答案的時候,並不會要求文件中存在相應的 import 語句,因此存不存在 import 語句不會影響最後的檢查結果。

寫完答案之後,我們還需要在同一個文件中,增加一個 Main 函數作為調試程式的執行入口,整個文件的程式碼結構如下:

class Main {      public static void main(String[] args) {          // Create a new Solution instance          Solution solution = new Solution();          // Create a test case          String testCase = "()[]{}";          // Get the answer          boolean answer = solution.isValid(testCase);          // Print the answer          System.out.println(answer);      }  }    class Solution {        ...        public boolean isValid(String s) {            ...            return answer;      }  }

此時我們會看到在 Main 函數的上方出現了兩個 CodeLens 按鈕:

點擊 Run 按鈕會運行 Main 函數,我們可以在下方彈出的 Debug Console 中看到程式的輸出結果(因為我們在最後一行程式碼用了 println 輸出答案)。

如果想要調試的話,可以在相應的行號位置設置好斷點,點擊 Debug 按鈕,就可以進入調試模式查看程式碼運行情況了。

這裡有一點需要注意的是,由於 LeetCode 生成的答題模板的類名均為 Solution,因此會造成同一個目錄下存在多個同名類的情況出現,可能導致程式碼無法正確執行,因此如果希望調試 LeetCode Java 程式碼,但當前目錄又存在有多個 LeetCode Java 文件時,需要保證類名的唯一性,我們可以把被調試的 Solution 類改一個名字(但要記住提交時把名字改回來),或者乾脆拷貝到另一個乾淨的目錄下調試即可。

以上就是如何在 VS Code 中調試 LeetCode Java 程式碼的步驟,對於其他語言來說,基本也是大同小異的步驟,如果你有更好的建議或者有自己喜歡的調試技巧,歡迎在評論區留言!

版權聲明

轉載時請註明作者 Fundebug以及本文地址: https://blog.fundebug.com/2019/04/20/debug-leetcode-in-vscode/

您的用戶遇到BUG了嗎?

體驗Demo 免費使用

.copyright *{box-sizing:border-box}