linux没有WideCharToMultiByte,MultiByteToWideChar,我们通常...

Linux下面的没有命名为 WideCharToMultiByte() 和 MultiByteToWideChar() 函数,WideCharToMultiByte,MultiByteToWideChar是windows下的函数,在linux下也有类似的两个函数:

mbstowcs()
wcstombs()

值得注意的是:

size_t mbstowcs(wchar_t *wcstr,const char *mbstr,size_t count);

这个函数的第三个参数count,大小一定要是mbstr长度的2倍,否则出来的中文也会是乱码

 

测试一下:

 

    setlocale(LC_ALL,"zh_CN.GB18030");
    wchar_t wcstr[20] = L"字符测试123abc";

    int len = wcslen(wcstr)+1;
    printf("len = %d /n",len);
    for(int i = 0; i < len; i++)
        printf("0x%08x ",wcstr[i]);
    printf("/n");

    char str[55] = {0};   
   

  • 10
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
WideCharToMultiByteMultiByteToWideCharWindows API中用于Unicode和多字节字符之间转换的函数。 举个例子,如果我们想要将一个Unicode字符串转换为多字节字符,可以使用WideCharToMultiByte函数。以下是一个示例代码: ```c++ // Unicode字符串 wchar_t unicodeStr[] = L"这是一个Unicode字符串"; // 转换为多字节字符 char mbStr[100]; WideCharToMultiByte(CP_UTF8, 0, unicodeStr, -1, mbStr, 100, NULL, NULL); // 输出结果 printf("多字节字符串:%s\n", mbStr); ``` 在上面的代码中,我们使用了WideCharToMultiByte函数将unicodeStr转换为多字节字符,并将结果存储在mbStr中。CP_UTF8参数指定了编码方式为UTF-8,-1参数表示转换整个字符串,100参数表示缓冲区大小为100。最后输出转换后的多字节字符。 同理,如果我们想要将一个多字节字符转换为Unicode字符串,可以使用MultiByteToWideChar函数。以下是一个示例代码: ```c++ // 多字节字符串 char mbStr[] = "这是一个多字节字符串"; // 转换为Unicode字符串 wchar_t unicodeStr[100]; MultiByteToWideChar(CP_UTF8, 0, mbStr, -1, unicodeStr, 100); // 输出结果 wprintf(L"Unicode字符串:%s\n", unicodeStr); ``` 在上面的代码中,我们使用了MultiByteToWideChar函数将mbStr转换为Unicode字符串,并将结果存储在unicodeStr中。CP_UTF8参数指定了编码方式为UTF-8,-1参数表示转换整个字符串,100参数表示缓冲区大小为100。最后输出转换后的Unicode字符串。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值