在用VScode 开发stm32的时候,有些场景下不得不用GB2312编码格式的c文件,如采用液晶中文字库等。常规的UTF-8格式下,一个中文字符占用3个字节,而GB2312是占用2字节的,为能让字库正常识别中文,不得不定义中文数组,编译的时候就是一堆警告。 如果想让 VS Code 的智能感知也识别这些参数(避免编辑器标红),同时方便一键编译,可修改c_cpp_properties.json和tasks.json:
解决方法:
1》修改tasks.json(一键编译用)
按 Ctrl+Shift+P → 输入
Tasks: Configure Task→ 选择Create tasks.json file from template→ 选择Others;修改生成的
tasks.json,添加编译参数:{ // See https://go.microsoft.com/fwlink/?LinkId=733558 // for the documentation about the tasks.json format "version": "2.0.0", "tasks": [ { "label": "echo", "type": "shell", "command": "echo Hello" }, { // 任务名称,自定义(比如 "编译menu_fun.c") "label": "build-menu-fun", "type": "shell", // 编译器路径(根据你的实际路径修改,嵌入式替换为 arm-none-eabi-gcc) "command": "arm-none-eabi-gcc", // 嵌入式编译器 "args": [ // 输出可执行文件名称(比如生成 menu_fun.exe) "-o", "${fileDirname}/App/OLED/menu_fun", // 要编译的文件:当前目录下的 menu_fun.c "${fileDirname}/App/OLED/menu_fun.c", // 核心:适配 GB2312 中文编码 "-finput-charset=GB2312", "-fexec-charset=GB2312", // 屏蔽中文数组触发的警告 "-Wno-multichar", // 可选:屏蔽其他可能的中文相关警告 "-Wno-implicit-int", "-Wno-unused-variable" ], // 设置为默认构建任务(按 Ctrl+Shift+B 可直接执行) "group": { "kind": "build", "isDefault": true }, // 识别 GCC 编译错误/警告 "problemMatcher": ["$gcc"], // 任务描述(可选) "detail": "编译 menu_fun.c(适配 GB2312 中文编码,屏蔽多字符警告)" } ] }示例中仅屏蔽了根目录/APP/OLED/menu_func.c,如有其他文件可依样添加。
2》修改c_cpp_properties.json(语法检查用)
tasks.json只负责编译,编辑器语法检查需单独配置c_cpp_properties.json,格式如下:
{ "configurations": [ { "name": "Win32", // 或 "ARM-GCC"(嵌入式) "includePath": ["${workspaceFolder}/**"], "defines": [], "compilerPath": "C:/MinGW/bin/gcc.exe", // 你的 GCC 路径 "cStandard": "c17", "cppStandard": "c++17", "intelliSenseMode": "gcc-x64", // 核心:添加编码和警告参数 "compilerArgs": [ "-finput-charset=GB2312", "-fexec-charset=GB2312", "-Wno-multichar" ] } ], "version": 4 }3》验证是否生效
编译完成后,可通过以下方式验证参数是否生效:
编译时无「multi-character character constant」「illegal character encoding」等警告;
运行生成的可执行文件,中文字符能正常显示(无乱码);
若用嵌入式编译器,可通过
arm-none-eabi-objdump -s test.elf查看字符串段,中文字符的十六进制值符合 GB2312 编码(如「中」是 0xD6 0xD0)。