launch.json文件
launch.json 文件是 Visual Studio Code (VS Code) 中用于设置调试会话的文件。它界说了调试器如何启动和运行步伐。以下是 launch.json 文件的详细设置说明,包括常见的属性及其用途。
基本结构
launch.json 文件通常位于 .vscode 目次下,具有以下基本结构:
- {
- "version": "0.2.0",
- "configurations": [
- {
- // 配置块
- }
- ]
- }
复制代码 主要属性
每个设置块代表一个调试设置,包含多个属性。以下是一些常见属性的说明:
- type: 调试器类型,如 python, cppdbg, node, java, 等。
- request: 调试哀求类型,通常为 launch(启动)或 attach(附加)。
- name: 设置名称,用户可以在调试设置列表中看到。
- program: 要调试的步伐路径或文件。
- args: 传递给步伐的下令行参数,数组形式。
- cwd: 当前工作目次。
- env: 情况变量设置。
- sourceMaps: 是否启用源映射(通常用于 JavaScript 调试)。
- preLaunchTask: 调试前要实验的任务(通常用于编译等)。
- postDebugTask: 调试竣事后要实验的任务。
- stopOnEntry: 是否在步伐入口处停止。
- console: 控制台类型,如 integratedTerminal, externalTerminal, 或 internalConsole。
- justMyCode: 是否只调试用户代码(用于 Python)。
- pythonPath: Python 可实验文件的路径(用于 Python)。
示例设置
以下是一些常见语言的 launch.json 设置示例:
Python
- {
- "version": "0.2.0",
- "configurations": [
- {
- "name": "Python: Current File",
- "type": "python",
- "request": "launch",
- "program": "${file}",
- "console": "integratedTerminal"
- }
- ]
- }
复制代码 C++
- {
- "version": "0.2.0",
- "configurations": [
- {
- "name": "C++: g++ build and debug active file",
- "type": "cppdbg",
- "request": "launch",
- "program": "${fileDirname}/${fileBasenameNoExtension}.out",
- "args": [],
- "stopAtEntry": false,
- "cwd": "${workspaceFolder}",
- "environment": [],
- "externalConsole": true,
- "MIMode": "gdb",
- "setupCommands": [
- {
- "description": "Enable pretty-printing for gdb",
- "text": "-enable-pretty-printing",
- "ignoreFailures": true
- }
- ],
- "preLaunchTask": "g++ build active file",
- "miDebuggerPath": "/usr/bin/gdb",
- "setupCommands": [
- {
- "description": "Enable pretty-printing for gdb",
- "text": "-enable-pretty-printing",
- "ignoreFailures": true
- }
- ],
- "miDebuggerArgs": "",
- "stopAtEntry": false,
- "logging": {
- "moduleLoad": false,
- "programOutput": false,
- "trace": false,
- "traceResponse": false
- },
- "windows": {
- "MIMode": "gdb",
- "miDebuggerPath": "gdb.exe"
- },
- "osx": {
- "MIMode": "lldb"
- },
- "pipeTransport": {
- "pipeProgram": "",
- "pipeArgs": [],
- "debuggerPath": "/usr/bin/gdb",
- "pipeCwd": ""
- },
- "sourceFileMap": {
- "/mnt/c": "c:\",
- "/mnt/d": "d:\"
- }
- }
- ]
- }
复制代码 Node.js
- {
- "version": "0.2.0",
- "configurations": [
- {
- "type": "node",
- "request": "launch",
- "name": "Launch Program",
- "skipFiles": ["<node_internals>/**"],
- "program": "${workspaceFolder}/app.js"
- }
- ]
- }
复制代码 常见设置项
1. Python
- program: 要调试的 Python 文件。
- pythonPath: Python 表明器路径。
- args: 传递给 Python 脚本的下令行参数。
- env: 情况变量。
- console: 控制台类型。
2. C++
- program: 可实验文件路径。
- args: 下令行参数。
- stopAtEntry: 是否在步伐入口处暂停。
- cwd: 当前工作目次。
- environment: 情况变量。
- externalConsole: 是否利用外部控制台。
- MIMode: 调试器模式(如 gdb, lldb)。
- miDebuggerPath: 调试器路径。
3. Node.js
- program: 要调试的 Node.js 文件。
- args: 下令行参数。
- runtimeExecutable: Node.js 可实验文件路径。
- runtimeArgs: 传递给 Node.js 的参数。
- env: 情况变量。
- sourceMaps: 是否启用源映射。
- outFiles: 编译输出文件路径。
利用示例
假设我们有一个 Python 项目,并且我们希望设置一个调试会话,可以如许写:
- {
- "version": "0.2.0",
- "configurations": [
- {
- "name": "Python: Current File",
- "type": "python",
- "request": "launch",
- "program": "${file}",
- "console": "integratedTerminal",
- "justMyCode": true
- }
- ]
- }
复制代码 这个设置会利用当前打开的 Python 文件作为步伐入口,运行调试,并在 VS Code 的集成终端中显示输出。
通过理解和正确设置 launch.json 文件,可以极大地提高调试效率和开发体验。差别语言和差别项目可能需要差别的设置,用户可以根据具体需求举行调解。
tasks.json
tasks.json 文件是 Visual Studio Code (VS Code) 中用于设置任务(Tasks)的文件。这些任务可以是编译代码、运行测试、构建项目等自动化任务。以下是 tasks.json 文件的详细设置说明,包括常见的属性及其用途。
基本结构
tasks.json 文件通常位于 .vscode 目次下,具有以下基本结构:
- {
- "version": "2.0.0",
- "tasks": [
- {
- // 任务配置块
- }
- ]
- }
复制代码 主要属性
每个任务设置块代表一个任务,包含多个属性。以下是一些常见属性的说明:
- label: 任务的名称或标签,用于在任务列表中标识任务。
- type: 任务类型,例如 shell 或 process。shell 表现任务将在 shell 中运行,process 表现任务将作为独立的进程运行。
- command: 要实验的下令,可以是编译器、构建工具、脚本等。
- args: 传递给下令的参数,数组形式。
- group: 任务分组,可以设置为 build 或 test,用于标识构建任务或测试任务。
- presentation: 控制任务输出的呈现方式,例如是否显示在终端中,是否清除之前的输出等。
- problemMatcher: 设置错误和警告的匹配器,用于从任务输出中解析错误和警告。
- options: 任务实验的选项,例如情况变量、当前工作目次等。
示例设置
以下是一些常见的 tasks.json 设置示例:
C++ 编译任务
- {
- "version": "2.0.0",
- "tasks": [
- {
- "label": "build"
- ,
- "type": "shell"
- ,
- "command": "g++"
- ,
- "args": [
- "-g",
- "${file}",
- "-o",
- "${fileDirname}/${fileBasenameNoExtension}.out"
- ],
- "group": {
- "kind": "build",
- "isDefault": true
- },
- "problemMatcher": ["$gcc"]
- ,
- "detail": "Generated task for building a C++ file using g++"
- }
- ]
- }
复制代码 Python 运行任务
- {
- "version": "2.0.0",
- "tasks": [
- {
- "label": "Run Python file",
- "type": "shell"
- ,
- "command": "python",
- "args": [
- "${file}"
- ],
- "group": {
- "kind": "build",
- "isDefault": true
- },
- "presentation": {
- "echo": true,
- "reveal": "always",
- "focus": false,
- "panel": "shared"
- },
- "problemMatcher": []
- }
- ]
- }
复制代码 Node.js 运行任务
- {
- "version": "2.0.0",
- "tasks": [
- {
- "label": "Run Node.js file",
- "type": "shell"
- ,
- "command": "node",
- "args": [
- "${file}"
- ],
- "group": {
- "kind": "build",
- "isDefault": true
- },
- "presentation": {
- "echo": true,
- "reveal": "always",
- "focus": false,
- "panel": "shared"
- },
- "problemMatcher": []
- }
- ]
- }
复制代码 常见设置项
任务的标签名称,用于在 VS Code 任务列表中标识任务。
任务类型,可以是 shell 或 process。shell 表现任务将在 shell 中运行,process 表现任务将作为独立的进程运行。
要实验的下令,例如编译器、脚本或构建工具。
传递给下令的参数,数组形式。
- "args": [
- "-g",
- "${file}",
- "-o",
- "${fileDirname}/${fileBasenameNoExtension}.out"
- ]
复制代码 任务分组,用于标识任务的类别,可以是 build 或 test。
- "group": {
- "kind": "build",
- "isDefault": true
- }
复制代码 控制任务输出的呈现方式。
- "presentation": {
- "echo": true,
- "reveal": "always",
- "focus": false,
- "panel": "shared"
- }
复制代码 用于解析任务输出中的错误和警告。VS Code 内置了多种匹配器,例如 $gcc, $eslint 等。
- "problemMatcher": ["$gcc"]
复制代码 任务实验的选项,例如情况变量、当前工作目次等。
- "options": {
- "cwd": "${workspaceFolder}"
- }
复制代码 利用示例
假设我们有一个 C++ 项目,并且我们希望设置一个编译任务,可以如许写:
- {
- "version": "2.0.0",
- "tasks": [
- {
- "label": "build"
- ,
- "type": "shell"
- ,
- "command": "g++"
- ,
- "args": [
- "-g",
- "${file}",
- "-o",
- "${fileDirname}/${fileBasenameNoExtension}.out"
- ],
- "group": {
- "kind": "build",
- "isDefault": true
- },
- "problemMatcher": ["$gcc"]
- ,
- "detail": "Generated task for building a C++ file using g++"
- }
- ]
- }
复制代码 这个设置会利用 g++ 编译当前打开的 C++ 文件,并将输出文件放在相同目次下,文件名与源文件相同但扩展名为 .out。
通过理解和正确设置 tasks.json 文件,可以极大地提高构建和运行任务的自动化和效率。差别语言和差别项目可能需要差别的设置,用户可以根据具体需求举行调解。
tasks.json与launch.json文件的区别
tasks.json 和 launch.json 是 Visual Studio Code (VS Code) 中用于设置差别类型任务的文件,它们各自有差别的用途和设置方式。
tasks.json
tasks.json 用于设置和管理各种任务,例如编译代码、运行脚本、构建项目等。它界说了一些可以自动实验的任务,主要用于自动化构建、测试和其他开发流程。
主要功能和用途:
- 编译代码:如编译 C++ 或 Java 代码。
- 运行脚本:如实验 Python 或 Shell 脚本。
- 构建项目:如利用构建工具(Make、Gradle、Maven)构建项目。
- 其他任务:如清算生成文件、打包等。
主要属性:
- label: 任务的名称或标签。
- type: 任务类型,例如 shell 或 process。
- command: 要实验的下令。
- args: 传递给下令的参数。
- group: 任务分组,可以设置为 build 或 test。
- presentation: 控制任务输出的呈现方式。
- problemMatcher: 设置错误和警告的匹配器。
- options: 任务实验的选项,例如情况变量、当前工作目次等。
示例:
- { "version": "2.0.0", "tasks": [ { "label": "build"
- , "type": "shell"
- , "command": "g++"
- , "args": [ "-g", "${file}", "-o", "${fileDirname}/${fileBasenameNoExtension}.out" ], "group": { "kind": "build", "isDefault": true }, "problemMatcher": ["$gcc"]
- } ]}
复制代码 launch.json
launch.json 用于设置调试器的启动和运行参数。它界说了调试设置,主要用于在调试会话中启动步伐、附加到正在运行的步伐等。
主要功能和用途:
- 启动调试会话:设置调试器如何启动步伐。
- 附加调试:设置调试器如何附加到正在运行的步伐。
- 设置断点和观察点:调试过程中设置断点和观察点。
主要属性:
- type: 调试器类型,如 python, cppdbg, node, java 等。
- request: 调试哀求类型,通常为 launch(启动)或 attach(附加)。
- name: 设置名称,用户可以在调试设置列表中看到。
- program: 要调试的步伐路径或文件。
- args: 传递给步伐的下令行参数。
- cwd: 当前工作目次。
- env: 情况变量设置。
- sourceMaps: 是否启用源映射(通常用于 JavaScript 调试)。
- preLaunchTask: 调试前要实验的任务(通常用于编译等)。
- postDebugTask: 调试竣事后要实验的任务。
- stopOnEntry: 是否在步伐入口处停止。
- console: 控制台类型,如 integratedTerminal, externalTerminal 或 internalConsole。
- justMyCode: 是否只调试用户代码(用于 Python)。
示例:
- {
- "version": "0.2.0",
- "configurations": [
- {
- "name": "Python: Current File",
- "type": "python",
- "request": "launch",
- "program": "${file}",
- "console": "integratedTerminal"
- }
- ]
- }
复制代码 主要区别
- 用途:
- tasks.json:用于设置和管理自动化任务(如编译、构建、运行脚本等)。
- launch.json:用于设置调试器,界说调试会话的启动和运行参数。
- 设置内容:
- tasks.json:界说要实验的任务及其参数和选项。
- launch.json:界说调试会话的参数和选项,包括要调试的步伐、调试器类型、启动或附加模式等。
- 工作流:
- tasks.json:实用于一样平常开发中的重复任务,自动化构建和测试流程。
- launch.json:实用于调试代码,启动调试会话或附加到正在运行的步伐。
结合利用
在许多情况下,tasks.json 和 launch.json 可以结合利用。例如,可以在 launch.json 中界说一个调试设置,并在调试前实验一个由 tasks.json 设置的编译任务:
- // launch.json
- {
- "version": "0.2.0",
- "configurations": [
- {
- "name": "C++ Debug",
- "type": "cppdbg",
- "request": "launch",
- "program": "${workspaceFolder}/a.out",
- "args": [],
- "stopAtEntry": false,
- "cwd": "${workspaceFolder}",
- "environment": [],
- "externalConsole": true,
- "MIMode": "gdb",
- "setupCommands": [
- {
- "description": "Enable pretty-printing for gdb",
- "text": "-enable-pretty-printing",
- "ignoreFailures": true
- }
- ],
- "preLaunchTask": "build"
- }
- ]
- }
复制代码- // tasks.json{ "version": "2.0.0", "tasks": [ { "label": "build"
- , "type": "shell"
- , "command": "g++"
- , "args": [ "-g", "${file}", "-o", "${fileDirname}/${fileBasenameNoExtension}.out" ], "group": { "kind": "build", "isDefault": true }, "problemMatcher": ["$gcc"]
- } ]}
复制代码 如许,当你启动调试会话时,VS Code 会先实验 tasks.json 中界说的编译任务,然后再启动调试。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |