控制台程序的中文输出乱码问题

这篇博客探讨了控制台程序在输出中文时遇到的乱码问题,主要涉及printf和wprintf函数以及setlocale函数的使用。文章通过示例代码展示了在Windows环境下VS2008和MinGW的不同输出,并解释了源文件编码、二进制文件存储和控制台输出编码之间的关系。解决方案是使用setlocale函数设置区域类型,确保与控制台环境编码一致。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

控制台程序的中文输出乱码问题,printf,wprintf与setlocale
复制代码
#include <stdio.h>
#include <wchar.h>
int main(void) {
char str[] = “中文”;
wchar_t wstr[] = L"中文";
printf(“1:%s\n”, str);
wprintf(L"2:%s\n", wstr);
return 0;
}
复制代码
Windows平台下VS2008输出:

Windows平台下MinGW输出:

当加上setlocale函数设定后,

复制代码
#include <stdio.h>
#include <locale.h>
#include <wchar.h>
int main(void) {
setlocale(LC_CTYPE, “”);
char str[] = “中文”;
wchar_t wstr[] = L"中文";
printf(“1:%s\n”, str);
wprintf(L"2:%s\n", wstr);
return 0;
}
复制代码
输出分别为:

为解其中各种纷乱的纠结,又让我一个美好的下午就此悲剧= =.

=============================================================分割线

这档子事还得从字符编码说起.关于字符集和编码的基础知识,请看咱昨天写的 字符集相关知识的简单总结.

这里涉及到一个字符在源代码(文本)中,编译好的二进制文件中,以及最后控制台输出编码形式的区别.

首先,要明确一点:C(语言/程序)并不理解ANSI,UTF-8以及任何其他编码.它只知道处理你给它的字符的二进制表示.

在简体中文Windows下,默认的文本保存编码是ANSI(即GBK

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值