【cpp/c++ summary 工具】Visual Studio 2022 安装与cmake项目配置

Visual Studio 2022安装

Visual Studio 2022创建cmake项目

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

Visual Studio 2022打开cmake项目

  • 点击打开带有cmakelists.txt的项目文件夹

在这里插入图片描述

  • 配置缓存:点击“项目”或右键CMakeLists.txt文件进行配置缓存

在这里插入图片描述

  • 由于缺少GCOV无法编译Gtest项目 : GCOV 是 GCC 的一部分
  • 以上测试代码中包含许多linux的cmake配置,换了另一个项目,运行如下:

在这里插入图片描述

<think>我们讨论的是Visual Studio Code其他编译软件(如Keil、IAR等嵌入式开发IDE)的同步问题。通常,这些IDE使用专有工程文件,而VSCode使用自己的配置文件。同步的关键在于让VSCode能够识别和利用这些编译软件的工程设置,以便在VSCode中编辑代码时能够获得正确的语法高亮、代码补全、错误检查和构建配置。 解决方案: 1. 使用VSCode的插件系统来支持其他编译软件的工程文件。 2. 手动配置VSCode的设置文件(如c_cpp_properties.json)来匹配编译软件的头文件路径、宏定义等。 3. 使用构建工具(如CMake)生成统一的构建描述文件,然后分别在VSCode和编译软件中使用。 这里以Keil MDK为例,展示如何配置VSCode来同步Keil工程。 步骤1:安装Keil MDK的VSCode插件 - 搜索并安装`Keil Studio Pack`(如果存在)或类似的插件。 步骤2:使用插件导入Keil工程 - 安装后,使用插件导入Keil工程(通常是.uvprojx文件),插件将解析工程设置并生成VSCode所需的配置文件。 步骤3:手动配置(如果没有合适插件) - 如果没有合适的插件,可以手动配置VSCode。 具体步骤: a) 在Keil中导出头文件路径和宏定义。可以在Keil的Target Options -> C/C++ 选项卡中找到这些信息。 b) 在VSCode中打开工程文件夹,按`Ctrl+Shift+P`,输入`C/C++: Edit Configurations (UI)`,打开配置界面。 c) 在配置界面中,添加头文件路径(Include path)和宏定义(Defines),这些信息来自Keil工程。 步骤4:配置构建任务 - 在VSCode中,可以配置构建任务来调用Keil的编译命令(uv4.exe)。 - 创建一个tasks.json文件,添加如下任务: ```json { "version": "2.0.0", "tasks": [ { "label": "Build Keil Project", "type": "shell", "command": "C:/Keil/UV4/UV4.exe", // 根据实际安装路径修改 "args": [ "-b", "${workspaceFolder}/project.uvprojx", // 工程文件路径 "-o", "build_log.txt" ], "group": { "kind": "build", "isDefault": true }, "problemMatcher": [] } ] } ``` 步骤5:调试配置(可选) - 如果需要调试,可以配置launch.json来使用Keil的调试器。 注意:由于Keil的编译器(armcc)和调试器VSCode的集成可能不够完美,调试配置可能比较复杂。 替代方案:使用CMake 如果项目允许,可以迁移到CMake来管理构建,这样可以在VSCode中直接使用CMake插件,同时Keil也可以使用CMake生成工程(通过插件或脚本)。 示例CMakeLists.txt(针对ARM Cortex-M): ```cmake cmake_minimum_required(VERSION 3.20) project(my_project C CXX ASM) # 设置目标芯片 set(CMAKE_SYSTEM_NAME Generic) set(CMAKE_SYSTEM_VERSION 1) set(CMAKE_SYSTEM_PROCESSOR cortex-m4) set(CMAKE_TRY_COMPILE_TARGET_TYPE STATIC_LIBRARY) # 指定编译器 set(TOOLCHAIN_PREFIX "C:/Keil_v5/ARM/ARMCC/bin") set(CMAKE_C_COMPILER "${TOOLCHAIN_PREFIX}/armcc.exe") set(CMAKE_CXX_COMPILER "${TOOLCHAIN_PREFIX}/armcc.exe") set(CMAKE_ASM_COMPILER "${TOOLCHAIN_PREFIX}/armasm.exe") set(CMAKE_LINKER "${TOOLCHAIN_PREFIX}/armlink.exe") # 添加源文件 file(GLOB_RECURSE SOURCES "src/*.c" "src/*.s") add_executable(firmware ${SOURCES}) # 添加头文件路径 target_include_directories(firmware PUBLIC "inc") # 添加链接脚本 target_link_options(firmware PUBLIC --scatter="linker_script.sct") ``` 然后在VSCode中安装CMake Tools插件,即可构建和调试。 总结:同步VSCode和其他编译软件的核心在于共享配置(头文件、宏、构建命令)。可以通过插件、手动配置或统一构建系统(如CMake)来实现。 §§相关问题§§: 1. 如何将Keil工程转换为CMake工程? 2. VSCode中如何配置嵌入式开发环境? 3. 如何使VSCode支持Keil的语法检查和代码补全? 4. 在VSCode中调试ARM Cortex-M程序有哪些方法? </think># Visual Studio Code 其他编译软件的同步方案 Visual Studio Code (VSCode) 其他编译软件(如 Keil、IAR、Eclipse 等)同步的关键在于建立统一的配置和工作流。以下是完整的解决方案: ## 方案一:使用 VSCode 作为前端编辑器 + 外部编译工具 ```jsonc // .vscode/settings.json { // 禁用 VSCode 的 C/C++ 扩展的自动配置 "C_Cpp.autocomplete": "Disabled", "C_Cpp.errorSquiggles": "Disabled", // 配置任务 "tasks.json": { "version": "2.0.0", "tasks": [ { "label": "Build with Keil", "type": "shell", "command": "C:\\Keil_v5\\UV4\\UV4.exe", "args": [ "-b", "${workspaceFolder}/project.uvprojx", "-o", "build_output.txt" ], "group": { "kind": "build", "isDefault": true }, "problemMatcher": ["$keil"] } ] }, // 配置问题匹配器 ".vscode/tasks.json": { "version": "2.0.0", "tasks": [ { // ... 同上 ... } ] }, // 配置启动器 "launch.json": { "version": "0.2.0", "configurations": [ { "name": "Debug with Keil", "type": "cppdbg", "request": "launch", "program": "${workspaceFolder}/output.axf", "miDebuggerPath": "C:\\Keil_v5\\ARM\\ARMCC\\bin\\arm-none-eabi-gdb.exe", "setupCommands": [ { "description": "Enable pretty-printing", "text": "-enable-pretty-printing", "ignoreFailures": true } ], "cwd": "${workspaceFolder}", "externalConsole": false, "MIMode": "gdb" } ] } } ``` ### 实现步骤: 1. **配置任务集成**: - 创建 `tasks.json` 文件调用外部编译工具(如 Keil 的 UV4.exe) - 添加问题匹配器解析编译错误(`$keil` 是自定义问题匹配器) 2. **配置调试集成**: - 使用 `launch.json` 连接到外部调试器 - 指定编译输出的可执行文件路径 3. **共享配置文件**: - 将 `.vscode` 文件夹添加到版本控制(Git) - 团队成员可以共享相同的 VSCode 配置 ## 方案二:使用统一的构建系统(如 CMake) ```cmake # CMakeLists.txt cmake_minimum_required(VERSION 3.20) project(MyProject C CXX ASM) # 设置交叉编译工具链 set(CMAKE_SYSTEM_NAME Generic) set(CMAKE_SYSTEM_PROCESSOR arm) # 指定编译器路径 set(TOOLCHAIN_PATH "C:/Keil_v5/ARM/ARMCC/bin") set(CMAKE_C_COMPILER "${TOOLCHAIN_PATH}/armcc.exe") set(CMAKE_CXX_COMPILER "${TOOLCHAIN_PATH}/armcc.exe") set(CMAKE_ASM_COMPILER "${TOOLCHAIN_PATH}/armasm.exe") # 添加源文件 file(GLOB_RECURSE SOURCES "src/*.c" "src/*.cpp" "src/*.s" ) # 添加头文件目录 include_directories( "inc" "lib/CMSIS/Include" ) # 添加编译选项 add_compile_options( --cpu=Cortex-M4 --apcs=interwork --c99 -DUSE_STDPERIPH_DRIVER ) # 创建可执行文件 add_executable(${PROJECT_NAME}.elf ${SOURCES}) # 链接选项 target_link_options(${PROJECT_NAME}.elf PRIVATE --strict --scatter="${CMAKE_SOURCE_DIR}/linker_script.sct" --map --list=output.map --summary_stderr --info summarysizes ) ``` ### 实现步骤: 1. **使用 CMake 作为统一构建系统**: - 创建跨平台的 `CMakeLists.txt` 文件 - 配置支持 Keil 编译器的工具链 2. **VSCode 集成**: ```jsonc // .vscode/settings.json { "cmake.configureSettings": { "CMAKE_TOOLCHAIN_FILE": "${workspaceFolder}/armcc.cmake" }, "cmake.buildDirectory": "${workspaceFolder}/build", "C_Cpp.default.configurationProvider": "ms-vscode.cmake-tools" } ``` 3. **IDE 集成**: - Keil: 使用 CMake 生成 Keil 项目文件 ```bash cmake -G "Keil uVision5" -B build ``` - VSCode: 使用 CMake Tools 扩展进行构建和调试 ## 方案三:远程开发同步工作区 ```jsonc // .devcontainer/devcontainer.json { "name": "Embedded Development", "build": { "dockerfile": "Dockerfile", "context": "." }, "remoteUser": "vscode", "extensions": [ "ms-vscode.cpptools", "ms-vscode.cmake-tools" ], "mounts": [ "source=/path/to/keil,target=/opt/keil,type=bind" ], "settings": { "terminal.integrated.shell.linux": "/bin/bash", "cmake.buildDirectory": "/workspace/build" } } ``` ### 实现步骤: 1. **创建 Docker 开发环境**: ```dockerfile # Dockerfile FROM ubuntu:20.04 # 安装工具链 RUN apt-get update && \ apt-get install -y build-essential cmake git # 复制 Keil 到容器(需有许可证) COPY keil /opt/keil # 配置环境变量 ENV PATH="/opt/keil/ARM/ARMCC/bin:${PATH}" ``` 2. **配置远程开发**: - 使用 VSCode 的 Remote - Containers 扩展 - 共享本地工作区到容器中 3. **统一工作流程**: - 所有开发者在相同的 Docker 环境中工作 - 编译工具链完全一致,避免环境差异 ## 方案四:使用智能同步脚本(Python) ```python import os import json import shutil from watchdog.observers import Observer from watchdog.events import FileSystemEventHandler class SyncHandler(FileSystemEventHandler): def __init__(self, src, dest): self.src = src self.dest = dest def on_modified(self, event): if not event.is_directory: rel_path = os.path.relpath(event.src_path, self.src) dest_path = os.path.join(self.dest, rel_path) # 排除不需要同步的文件 if not rel_path.startswith(('.vscode', 'build', 'Debug')): print(f"Syncing {rel_path}") shutil.copy2(event.src_path, dest_path) def sync_projects(vscode_path, keil_path): # 创建双向同步 vscode_handler = SyncHandler(vscode_path, keil_path) keil_handler = SyncHandler(keil_path, vscode_path) # 设置观察者 vscode_observer = Observer() keil_observer = Observer() vscode_observer.schedule( vscode_handler, vscode_path, recursive=True ) keil_observer.schedule( keil_handler, keil_path, recursive=True ) vscode_observer.start() keil_observer.start() try: while True: time.sleep(1) except KeyboardInterrupt: vscode_observer.stop() keil_observer.stop() vscode_observer.join() keil_observer.join() if __name__ == "__main__": # 配置文件路径 config = { "vscode_project": "/path/to/vscode/project", "keil_project": "/path/to/keil/project" } sync_projects( config["vscode_project"], config["keil_project"] ) ``` ### 实现步骤: 1. **安装依赖**: ```bash pip install watchdog ``` 2. **运行同步脚本**: ```bash python sync_projects.py ``` 3. **特性**: - 实时双向同步源文件 - 排除构建目录和配置文件 - 自动检测文件更改 ## 最佳实践总结 1. **文件组织结构**: ``` project/ ├── .vscode/ # VSCode 配置 ├── cmake/ # CMake 工具链文件 ├── docs/ # 文档 ├── drivers/ # 硬件驱动 ├── inc/ # 头文件 ├── src/ # 源文件 ├── build/ # 构建输出 ├── .gitignore ├── CMakeLists.txt # 统一构建配置 └── README.md ``` 2. **版本控制配置**: ```gitignore # .gitignore .vscode/launch.json .vscode/tasks.json build/ Debug/ *.hex *.bin *.axf ``` 3. **团队协作建议**: - 使用统一的开发容器(Docker) - 共享 CMake 配置VSCode 扩展推荐 - 定期同步工具链版本
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值