0

0

怎么用VSCode运行代码_VSCode代码执行与调试教程

蓮花仙者

蓮花仙者

发布时间:2025-08-28 10:05:01

|

1555人浏览过

|

来源于php中文网

原创

VSCode中运行和调试代码的核心方法包括:1. 使用内置终端手动执行命令,灵活但需重复输入;2. 通过Code Runner插件一键运行,快捷但功能有限;3. 借助语言扩展与调试器深度调试,支持断点、变量监控、调用堆栈等高级功能,适合复杂项目。配置时需安装对应语言扩展、设置解释器路径、合理使用settings.json和tasks.json,并正确配置launch.json以实现高效开发。常见问题如“Command not found”多因环境变量或工作目录错误,乱码问题源于编码不一致,模块导入错误通常因依赖未安装或环境不匹配,调试失败常因launch.json配置不当,逐一排查可解决。

怎么用vscode运行代码_vscode代码执行与调试教程

VSCode作为一款轻量级但功能强大的代码编辑器,其代码运行和调试能力是许多开发者选择它的关键。简单来说,在VSCode里跑代码,你可以通过内置终端手动执行命令,也可以利用方便的Code Runner插件一键运行,而更深入的调试则依赖于各语言的专属扩展和强大的调试器。选择哪种方式,往往取决于你项目的复杂度和具体需求。

解决方案

在VSCode中运行和调试代码,主要有以下几种核心方法,它们各有侧重,适用于不同的场景:

1. 利用内置终端手动执行代码

这是最基础也最灵活的方式。VSCode集成了功能完备的终端,你可以像在系统命令行一样,直接输入命令来运行你的代码。

  • 如何打开: 通常通过快捷键
    Ctrl +
    (反引号)
    或者点击菜单栏
    终端(Terminal) -> 新建终端(New Terminal)
  • 执行示例:
    • Python:
      python your_script.py
    • Node.js (JavaScript):
      node your_script.js
    • C/C++ (编译后运行):
      • gcc your_code.c -o your_code
        (编译)
      • ./your_code
        (运行)
    • Java (编译后运行):
      • javac YourClass.java
        (编译)
      • java YourClass
        (运行)
  • 优点: 灵活性高,完全掌控执行过程,适合各种语言和复杂的命令行参数。
  • 缺点: 每次运行都需要手动输入命令,对于频繁测试的小片段代码可能稍显繁琐。

2. 使用Code Runner扩展一键运行

对于那些只想快速看到代码执行结果、不涉及复杂配置或调试的场景,Code Runner扩展简直是神器。

  • 安装: 在VSCode扩展市场搜索 "Code Runner" 并安装。
  • 如何使用: 安装后,你会在编辑器的右上角看到一个“运行”按钮(类似播放图标),或者在代码文件内右键选择
    Run Code
    ,也可以使用快捷键
    Ctrl+Alt+N
  • 优点: 极其方便快捷,一键执行,结果直接显示在输出窗口。
  • 缺点: 主要用于简单的代码执行,对复杂的项目结构、命令行参数传递或交互式输入支持有限,也不提供调试功能。

3. 借助语言扩展和内置调试器进行深度调试

这是VSCode最强大的功能之一,也是开发复杂应用时不可或缺的工具。它允许你逐行执行代码,检查变量状态,跟踪程序流程。

  • 核心概念:

    • 语言扩展: 每种语言通常都有官方或社区提供的VSCode扩展(如Python扩展、JavaScript/TypeScript扩展、C/C++扩展等),它们提供了语言支持、智能感知、格式化以及最重要的——调试器集成。
    • launch.json
      文件:
      这是VSCode调试器的配置文件,定义了如何启动你的应用程序进行调试。它位于工作区根目录下的
      .vscode
      文件夹中。
    • 断点 (Breakpoints): 在代码行号旁边点击即可设置,程序执行到此处会暂停。
  • 调试步骤:

    1. 安装语言扩展: 根据你的编程语言,在扩展市场安装对应的扩展。
    2. 配置
      launch.json
      • 打开调试视图(左侧边栏的虫子图标)。
      • 点击齿轮图标,选择你的环境(例如
        Python
        Node.js
        )。VSCode会自动生成一个基础的
        launch.json
        文件。
      • 根据需要修改配置,例如指定启动文件 (
        program
        )、传递参数 (
        args
        )、设置工作目录 (
        cwd
        ) 等。
      • 示例 (Python):
        {
            "version": "0.2.0",
            "configurations": [
                {
                    "name": "Python: Current File",
                    "type": "python",
                    "request": "launch",
                    "program": "${file}", // 调试当前打开的文件
                    "console": "integratedTerminal", // 在集成终端运行
                    "justMyCode": true
                }
            ]
        }
      • 示例 (Node.js):
        {
            "version": "0.2.0",
            "configurations": [
                {
                    "type": "node",
                    "request": "launch",
                    "name": "Launch Program",
                    "skipFiles": [
                        "/**"
                    ],
                    "program": "${workspaceFolder}/app.js" // 调试项目根目录下的app.js
                }
            ]
        }
    3. 设置断点: 在你想要程序暂停的代码行号左侧点击,会出现一个红点。
    4. 启动调试: 在调试视图中选择正确的配置,然后点击绿色的“播放”按钮(或按
      F5
      )。
    5. 调试操作: 程序会在断点处暂停。你可以使用调试控制面板上的按钮进行操作:
      • F10
        (Step Over): 逐行执行,跳过函数内部。
      • F11
        (Step Into): 进入函数内部执行。
      • Shift+F11
        (Step Out): 跳出当前函数。
      • F5
        (Continue): 继续执行直到下一个断点或程序结束。
      • Shift+F5
        (Stop): 停止调试。
    6. 查看变量: 在调试视图的“变量”面板中,你可以实时查看当前作用域内所有变量的值。
  • 优点: 能够深入理解代码执行逻辑,定位和修复bug效率极高,支持条件断点、日志点、观察表达式等高级功能。

  • 缺点: 需要一定的配置学习成本,特别是

    launch.json
    的编写。

    吉卜力风格图片在线生成
    吉卜力风格图片在线生成

    将图片转换为吉卜力艺术风格的作品

    下载

如何配置VSCode以高效运行特定语言代码?

配置VSCode以适应不同语言的高效运行,其实就是为你的开发环境“量身定制”一套工具链。这不仅仅是安装一个扩展那么简单,更涉及到对解释器/编译器的管理、环境路径的设置,甚至是工作区特定的行为调整。我个人觉得,这一步做得好不好,直接影响了后续开发的流畅度。

1. 安装核心语言扩展: 这是第一步,也是最重要的一步。比如,如果你写Python,就得安装“Python”扩展;写JavaScript/TypeScript,那“JavaScript and TypeScript Language Features”是内置的,但你可能还需要“ESLint”、“Prettier”等来辅助。C++开发者则需要“C/C++”扩展。这些扩展不仅提供语法高亮、智能感知,更重要的是它们集成了语言服务器和调试器。

2. 配置语言解释器/编译器路径: 很多时候,VSCode并不知道你的Python解释器装在哪里,或者你的Java JDK路径在哪。

  • Python: 安装Python扩展后,它通常会提示你选择一个Python解释器。你可以在VSCode底部的状态栏点击当前显示的Python版本,或者通过
    Ctrl+Shift+P
    搜索
    Python: Select Interpreter
    来指定。如果你用虚拟环境(我强烈推荐这么做),这里选择虚拟环境里的解释器非常关键。
  • Node.js: Node.js通常是全局安装的,VSCode通常能自动找到。但如果你有多个Node.js版本管理工具(如
    nvm
    ),确保终端中激活的是你想要的版本。
  • C/C++: 你需要确保系统上安装了GCC、Clang或MSVC等编译器。VSCode的C/C++扩展会尝试找到它们。如果找不到,你需要手动配置
    c_cpp_properties.json
    文件,指定编译器的路径。
  • Java: 安装“Extension Pack for Java”后,它会引导你设置JDK路径。

3.

settings.json
的妙用: VSCode的
settings.json
文件是你的配置中心。你可以在这里定义全局设置,也可以为特定的工作区(项目)定义局部设置。

  • 全局设置: 影响所有项目。比如,你可以设置
    files.autoSave
    onFocusChange
    ,或者
    editor.fontSize
  • 工作区设置: 仅对当前项目生效。比如,你可能希望某个项目的Python解释器固定在特定的虚拟环境中,或者为某个项目禁用某个扩展。在
    .vscode
    文件夹下创建
    settings.json
    就可以实现。我经常用它来定义特定项目的代码格式化规则,这样团队协作时大家的代码风格就能保持一致。

4. 任务(Tasks)配置: 对于一些需要编译、打包或者运行测试的场景,VSCode的任务功能非常实用。你可以通过

Ctrl+Shift+P
搜索
Tasks: Configure Task
来创建
tasks.json
文件。

  • 示例 (编译C++):
    {
        "version": "2.0.0",
        "tasks": [
            {
                "label": "build my c++ project",
                "type": "shell",
                "command": "g++",
                "args": [
                    "-g",
                    "${file}",
                    "-o",
                    "${fileDirname}/${fileBasenameNoExtension}"
                ],
                "group": {
                    "kind": "build",
                    "isDefault": true
                },
                "problemMatcher": [
                    "$gcc"
                ],
                "detail": "Generated task for C++ build"
            }
        ]
    }

    这样,你就可以通过

    Ctrl+Shift+B
    一键编译当前C++文件了。

配置的精髓在于,它让你能更少地去想“怎么运行”,而更多地去关注“写什么代码”。一开始可能有点摸不着头脑,但一旦掌握了,效率提升是巨大的。

调试功能在VSCode中如何发挥最大作用?

VSCode的调试功能,在我看来,是它最能体现“生产力工具”价值的地方。它不仅仅是让代码跑起来,更是让你能“看透”代码在做什么。要让调试功能发挥最大作用,我们需要跳出“F5然后等结果”的思维定式,真正去利用它的各种高级特性。

1. 深入理解断点类型: 断点不只有普通断点。

  • 条件断点 (Conditional Breakpoints): 当你只关心某个特定条件发生时的代码状态时,这个功能非常有用。右键点击断点,选择“编辑断点”,然后输入一个条件表达式。比如,在一个循环里,你可以设置
    i == 100
    ,这样只有当
    i
    等于100时程序才会暂停。这比你手动点100次“下一步”要高效得多。
  • 日志点 (Logpoints): 有时候你不想程序暂停,只是想在特定位置输出一些变量的值。日志点就是为此设计的。它不会中断程序执行,而是在调试控制台输出你指定的信息。这就像在代码里加了
    console.log()
    print()
    ,但你不需要修改代码,也不需要重新启动程序。
  • 函数断点 (Function Breakpoints): 在某些语言(如JavaScript)中,你可以在函数名上设置断点,无论该函数在哪里被调用,都会暂停。
  • 异常断点 (Exception Breakpoints): 在调试视图的“断点”面板里,你可以勾选在捕获或未捕获的异常处暂停。这对于定位那些意料之外的错误非常有帮助。

2. 善用变量、监视和调用堆栈: 调试时,这三个面板是你的眼睛。

  • 变量 (Variables): 实时显示当前作用域内所有变量的值。它会随着你单步执行而动态更新。理解变量的生命周期和作用域变化,是解决bug的关键。
  • 监视 (Watch): 你可以手动添加你特别关心的变量或表达式到“监视”面板。即使这些变量不在当前作用域内,或者你需要查看一个复杂表达式的实时结果,它都能帮你。比如,你可以监视一个对象的某个深层属性,或者一个函数的返回值。
  • 调用堆栈 (Call Stack): 显示程序当前执行到的函数调用链。通过它,你可以清晰地看到程序是如何从一个函数跳到另一个函数的,这对理解程序流程和定位问题来源至关重要。我经常通过查看调用堆栈来回溯,找出哪个函数调用导致了当前的状态异常。

3.

launch.json
的高级配置:
launch.json
远不止定义一个
program
路径那么简单。

  • request
    类型:
    除了最常见的
    launch
    (启动并调试新进程),还有
    attach
    (附加到已运行的进程)。当你需要调试一个已经在运行的服务,或者一个容器内的应用时,
    attach
    就派上用场了。
  • 环境配置 (
    env
    ,
    envFile
    ):
    你可以在这里设置环境变量,这对一些依赖特定环境配置的应用程序非常有用。比如数据库连接字符串、API密钥等。
  • 工作目录 (
    cwd
    ):
    确保你的程序在正确的目录下运行,特别是当你的程序需要读取相对路径文件时。
  • 多配置和复合启动 (Compound Launch): 你可以在
    launch.json
    中定义多个调试配置,甚至创建一个“复合启动”来同时启动并调试多个服务(比如前端和后端)。这对于微服务架构或者全栈开发来说是极其强大的功能。

4. 远程调试: 当你开发的应用程序运行在虚拟机、Docker容器或者远程服务器上时,VSCode的远程调试功能就显得尤为重要。这通常需要特定的语言扩展支持,并在远程机器上安装相应的调试代理。配置过程可能略复杂,但一旦设置好,你就能像调试本地代码一样调试远程代码,大大提升了开发效率。

在我看来,调试不仅仅是找出bug,更是一种学习和理解代码运行机制的有效方式。当你一步步跟着代码走,观察变量变化,理解调用堆栈,你会对程序的内部运作有更深刻的认识。

运行代码时常见的坑和解决方案是什么?

在VSCode里运行代码,哪怕是经验丰富的开发者,也难免会遇到一些“小插曲”。这些问题往往不涉及复杂的逻辑错误,而是环境、配置或路径等基础性的“坑”。理解这些常见问题及其解决方案,能帮你省下不少抓耳挠腮的时间。

1. “Command not found”或“No such file or directory”:路径与环境配置的噩梦

  • 问题描述: 这是最常见的错误之一。终端提示找不到你的解释器(如
    Python
    node
    )或者找不到你试图运行的文件。
  • 深层原因:
    • 系统PATH环境变量问题: 你的操作系统没有将解释器/编译器的安装路径添加到环境变量中,导致终端无法识别这些命令。
    • VSCode工作区路径问题: 你在终端中执行命令时,当前的工作目录不是你代码文件所在的目录,或者你的代码引用了错误的相对路径。
    • 虚拟环境未激活: 对于Python等语言,如果你使用了虚拟环境,但终端中没有激活它,那么它将找不到虚拟环境特有的库或解释器。
  • 解决方案:
    • 检查系统PATH: 确保你的编程语言解释器/编译器的安装目录已经正确添加到系统的PATH环境变量中。在Windows上,这通常在“系统属性”->“高级”->“环境变量”中设置;在macOS/Linux上,通常在
      .bashrc
      .zshrc
      文件中配置。
    • 确认VSCode工作区: 确保你打开的是包含你代码的正确文件夹。在终端中,可以使用
      pwd
      (Linux/macOS) 或
      cd
      (Windows) 命令查看当前目录,并使用
      cd
      命令切换到正确的目录。
    • 激活虚拟环境: 如果使用Python虚拟环境,在VSCode终端中手动激活它(例如
      source .venv/bin/activate
      ),或者在VSCode的Python扩展中选择正确的解释器,它通常会自动激活。
    • 检查文件路径: 确保你的代码中引用的任何文件路径都是正确的,特别是相对路径。

2. 乱码问题:编码不统一的烦恼

  • 问题描述: 终端输出中出现无法识别的字符,或者你的代码在读取文件时出现编码错误。
  • 深层原因: 你的代码文件编码、终端编码和程序读取文件时指定的编码不一致。
  • 解决方案:
    • 统一文件编码: 尽量将所有代码文件保存为UTF-8编码。VSCode默认就是UTF-8,但如果你从其他编辑器复制过来或者下载的文件,可能不是。你可以在VSCode右下角点击编码类型(通常是“UTF-8”),然后选择“通过编码重新打开”或“通过编码保存”。
    • 设置终端编码: 确保VSCode集成终端的编码设置与你的系统终端编码一致。在
      settings.json
      中,可以设置
      terminal.integrated.defaultProfile.windows
      terminal.integrated.shellArgs.linux
      等,确保终端能正确显示UTF-8字符。
    • 程序内指定编码: 在你的代码中明确指定文件读写时的编码。例如,Python中
      open('file.txt', 'r', encoding='utf-8')

3. “Module not found”或“ImportError”:依赖管理不当

  • 问题描述: 你的程序运行时提示找不到某个模块或库。
  • 深层原因:
    • 依赖未安装: 你在代码中使用了某个库,但没有通过包管理器(如
      pip
      npm
      )安装它。
    • 安装到错误的环境: 库安装到了全局环境,而你的程序运行在虚拟环境中,或者反之。
  • 解决方案:
    • 安装缺失的依赖: 根据你的语言,使用相应的包管理器安装。例如
      pip install requests
      (Python) 或
      npm install express
      (Node.js)。
    • 确保环境一致: 如果你使用了虚拟环境,请确保你在激活虚拟环境的终端中安装了所有依赖。VSCode的Python扩展在这方面做得很好,它会根据你选择的解释器自动使用对应的包管理器。
    • 检查
      requirements.txt
      /
      package.json
      确保所有依赖都列在项目配置文件中,并定期更新。

4. 调试器无法启动/附加:

launch.json
配置错误

  • 问题描述: 启动调试时,调试器没有按预期工作,或者报错“无法附加到进程”。
  • 深层原因:
    launch.json
    文件中的配置项有误,比如
    program
    路径不对,或者
    port
    冲突,或者调试器类型 (
    type
    ) 不匹配。
  • 解决方案:
    • 仔细检查
      launch.json
      确保
      program
      字段指向正确的启动文件,
      cwd
      (工作目录) 设置正确。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

420

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

536

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

77

2025.09.10

pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

339

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

415

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

761

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

349

2025.07.23

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

7

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
go语言零基础开发内容管理系统
go语言零基础开发内容管理系统

共34课时 | 2.6万人学习

第二十三期_前端开发
第二十三期_前端开发

共98课时 | 7.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号