通过Mingw64交叉编译Windows程序时,会经常为了适配使用到一些C库的函数,但是Windows平台相较于Linux平台对于C库的函数支持性有一定的差距!
在做文件系统时,当获取文件、目录的详细信息时,会使用的stat函数,该函数再Linux环境下没有什么使用的问题,但是再Window环境下,对于 char*字符串中带的中文路径支持度不够,适配跨平台时,需要使用_wstat64宽字节函数对应!解决该问题!
char u8str[] = u8"D://你好你好";
WCHAR uni_buf[MAX_PATH] = { 0 };
int len = MultiByteToWideChar(CP_ACP , 0, u8str, -1, NULL, 0);
MultiByteToWideChar(CP_UTF8, 0, u8str, -1, uni_buf, len);
result = _wstat64(uni_buf, &buf);
setlocale(LC_ALL, "");
printf("printf content start: %ls", uni_buf);
cmd客户端打印utf-8的字符串方式 :
输入 chcp 65001 即输出的是utf-8
输入 chcp 936 即是默认的GBK
宽字节转多字节 wchar_t*转char
使用vs tudio编译
WCHAR uni_buf[MAX_PATH] = L"H://你好//你好";
char* pAssii = (char*)malloc(MAX_PATH);
int len = WideCharToMultiByte(CP_ACP, 0, uni_buf, -1, NULL, 0, NULL, NULL);
WideCharToMultiByte(CP_ACP, 0, uni_buf, -1, pAssii, len, NULL, NULL);
mingw64编译
WCHAR uni_buf[MAX_PATH] = L"H://你好//你好";
char* pAssii = (char*)malloc(MAX_PATH);
int len = WideCharToMultiByte(CP_UTF8, 0, uni_buf, -1, NULL, 0, NULL, NULL);
WideCharToMultiByte(CP_UTF8, 0, uni_buf, -1, pAssii, len, NULL, NULL);