欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

vscode配置cygwin的gcc编译器下,编译(不运行)linux c语言程序

程序员文章站 2022-06-04 12:38:19
...
  1. 安装extension(扩展):C/C++
    vscode配置cygwin的gcc编译器下,编译(不运行)linux c语言程序

  2. 在此按钮下有自动配置的选项,生成.vscode文件夹,如果没有则自己创建。
    vscode配置cygwin的gcc编译器下,编译(不运行)linux c语言程序

  3. 下面包含三个文件:c_cpp_properties.json, launch.json, Tasks.json。没有的话就自己创建。
    vscode配置cygwin的gcc编译器下,编译(不运行)linux c语言程序
    代码分别如下:

//c_cpp_properties.json
{
    "configurations": [
        {
            "name": "Win32",
            "includePath": [
            	//这里用来配置include的路径,如果没有则vscode下会显示报错但仍可编译
                "${workspaceFolder}/**",
                "E:/Software/cygwin64/lib/gcc/x86_64-pc-cygwin/10/include",
                "E:/Software/cygwin64/usr/include",
                "E:/Software/cygwin64/usr/lib/gcc/x86_64-pc-cygwin/10/../../../../lib/../include/w32api"
            ],
            "defines": [
                "_DEBUG",
                "UNICODE",
                "_UNICODE"
            ],
            "compilerPath": "E:\\Software\\cygwin64\\bin\\gcc.exe",
            "cStandard": "gnu17",
            "cppStandard": "gnu++14",
            "intelliSenseMode": "windows-gcc-x64"
        }
    ],
    "version": 4
}
// launch.json
{
    // 使用 IntelliSense 了解相关属性。 
    // 悬停以查看现有属性的描述。
    // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": [

        {
           "name": "C++ Launch (GDB)",                 // 配置名称,将会在启动配置的下拉菜单中显示
            "type": "cppdbg",                           // 配置类型,这里只能为cppdbg
            "request": "launch",                        // 请求配置类型,可以为launch(启动)或attach(附加)
            "targetArchitecture": "x64",                // 生成目标架构,一般为x86或x64,可以为x86, arm, arm64, mips, x64, amd64, x86_64
            "program": "${workspaceRoot}/${fileBasenameNoExtension}.exe",                   // 将要进行调试的程序的路径
            "miDebuggerPath":"e:/Software/cygwin64/bin/gdb.exe", // miDebugger的路径,注意这里要与cygwin/MinGw的路径对应
            "args": ["blackkitty",  "1221", "# #"],     // 程序调试时传递给程序的命令行参数,一般设为空即可
            "stopAtEntry": false,                       // 设为true时程序将暂停在程序入口处,一般设置为false
            "cwd": "${workspaceRoot}",                  // 调试程序时的工作目录,一般为${workspaceRoot}即代码所在目录
            "externalConsole": false,                    // 调试时是否显示控制台窗口,一般设置为true显示控制台
            //这里我直接选择false,因为运行默认会用cmd(windows)打开
            "preLaunchTask": "gcc"
        }
    ]
}

//Tasks.json
{
    "version": "2.0.0",
    "command": "gcc",//对应"preLaunchTask"c++为g++, c为gcc
    "args": ["-g","${file}","-o","${workspaceFolder}/${fileBasenameNoExtension}.exe"],    // 编译命令参数
    "problemMatcher": {
        "owner": "cpp",
        "fileLocation": ["relative", "${workspaceRoot}"],
        "pattern": {
            "regexp": "^(.*):(\\d+):(\\d+):\\s+(warning|error):\\s+(.*)$",
            "file": 1,
            "line": 2,
            "column": 3,
            "severity": 4,
            "message": 5
        }
    }
}

如果需要在vscode下打开cygwin的命令行,则可以更改vscode的settings.json文件。

"terminal.integrated.profiles.windows": {
        "cygwin": {
            "path": "E:\\Software\\cygwin64\\bin\\bash.exe" //自己的cygwin路径
        }
    },

vscode配置cygwin的gcc编译器下,编译(不运行)linux c语言程序

vscode配置cygwin的gcc编译器下,编译(不运行)linux c语言程序