问题描述
我正在使用带有 mingw-w64(gcc 版本 8.1.0,x86_64-posix-sjlj-rev0,由 MinGW-W64 项目构建)和 cmd
的 Microsoft Windows 10。当我尝试在 Windows 控制台上打印或存储然后打印西班牙语字符时,它显示错误。例如我试图执行这个程序:
#include <stdio.h>
int main(void) {
char c[20];
printf("pía\n");
scanf("%s",c);
printf("%s",c);
}
如果我引入一些西班牙语字符,返回的句子是可以的,但开头的打印句显示错误:
pía
laíóñaú
laíóñaú
一些解决方案建议放置 setlocale()
函数,但结果相同。其他解决方案是将 UTF-8 unicode 兼容性放在区域设置中:
但现在错误相反,打印出来的没问题,但是当我引入一个奇怪的字符时,控制台不显示它:
pía
lía
l
有点令人沮丧,因为我看到的所有解决方案都是通过上述方法或通过设置 setlocale()
解决的,但它们都不适合我,我不知道为什么。
编辑
正如 Mofi 在评论中所说,我尝试使用 SetConsoleCP()
和 SetConsoleOutputCP()
来更改控制台的代码页。在没有完全理解这些函数是如何工作的情况下,使用与上面相同的代码,我运行了几个错误结果的示例:
pía | p├¡a | p├¡a | pía
lía | lía | lía | lía
l | l | lía | la
input: 65001 output 65001 | input: 65001 output 850 | input: 850 output 850 | input: 850 output 65001
我怎么不完全理解这个函数我不知道为什么在最后一个例子中,控制台不显示重音存储的字符,但在打印出来的字符中它会显示,而在上面的例子中,情况正好相反。
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)