WCHAR

2024-03-06 00:38
文章标签 wchar

本文主要是介绍WCHAR,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

比较用wcscmp()

赋值用 WCHAR s[] = L"abc";


宽字符已经困扰我很久了,以前我都是设置项目的属性把它改为多字节,不用UNICODE。不过现在又遇到宽字节的问题,没有办法,只有硬着头皮学学:
我找到的资料:
http://hi.baidu.com/shongbee2/blog/item/207925546b6cdd5fd10906e0.html
http://hi.baidu.com/shongbee2/blog/item/d4a057511e9539878c5430cb.html
看了之后我才发现原来有wcsXXX的函数专门处理宽字节的,就是strXXX一样好使。呵呵,我不再惧怕了,就试着自己写了一下,还是学了蛮多东西的:
1.有wcsXXX的函数和strXXX的函数对应处理宽字节,wcslen就是求长度的,wcscmp就是比较两个字符串的。
2.输出也有相关的操作,wprintf(L”%s%s”);这样的操作,对文件也可以用fwprintf函数来输出。不过我发现貌似cout << wchar;不成功。也发现了一个问题,就是我输出”相等”这样一个字符串的时候,发现居然输出不正确,无论是控制台和文件都有错误。可见,这个还是有点小问题的。输出其他的例如”12345”等都是正常的。哎,这个函数并不可靠啊。
3.宽字节和普通串的转换问题,学了两个函数,一个是:
wcstombs(char* strDes, const wchar*, size_t nMax);这个函数的作用是把wchar转换为char。
char* strDes 为保存转换后的普通字符串,wchar* 要被转换的宽字符串。转换的最大长度。这里的长度是转换的个数,而不是字节长度。
mbstowcs() 就是一个相反的过程了,参数就不说了。


另一套转换的函数是:
int WideCharToMultiByte(
  UINT CodePage, 
  DWORD dwFlags, 
  LPCWSTR lpWideCharStr,
  int cchWideChar, 
  LPSTR lpMultiByteStr, 
  int cbMultiByte,
  LPCSTR lpDefaultChar,    
  LPBOOL lpUsedDefaultChar
);
他的参数很多,上面的连接有介绍,这里就不怎么细说了。
第一个是编码的方式,我一般用CP_ACP。第二个是转换标志,MSDN上说什么都不设置更快,然后我就什么都不管了就用NULL了。具体作用不知道,等遇到了再学。第三个参数就是被转换的字符串,第四个参数是该字符串的长度,-1表示自动算长度,如果是手动给出,一定要把最后的终结符长度也算上。我觉得还是-1来的实际。第五个参数就是保存转换串的指针,第六个参数就是保存串的长度,这里是单位字符的个数。如果转换的时候没有终结符,那么结果也没有终结符,要注意下。最后两个参数就是默认的填充字符和是否使用了默认填充字符,我一般就用NULL代替。


普通串转宽字节也是类似。
这里有几个注意的,一定要保证空间足够。还有就是那个长度是单位字符个数,而不是字节数,在转换时,推荐被转换的字符串长度设置为-1,因为这样他会自动算出终结符结束。返回值也是转换的单位字符个数。例如”相等”有普通串转换为宽字节串,返回结果是3,(有终结符),而反过来就是5。如果返回时0 说明转换失败。


心得:虽然WideCharToMultiByte的参数要多,感觉用的没有wcstombs爽,可是他的准确好高一些,要转换的话,还用用WideCharToMultiByte比较合适,还有就是虽然有一套wcsXXX的库函数,可惜输出还是出现问题的。如果全都用宽字节,那没有关系wcsxxx的函数还是蛮好用的。还有一个疑惑我明明查字典multi是多的意思也就是说multibyte是多字节,我的中文版VS2005配置里面也是说的多字节。搞不懂为什么要用宽字节呢?可能是多字节编码不好用吧。呵呵。 废话也说完了,奉上源代码:
#include <iostream>
#include <fstream>
#include <windows.h>
using namespace std;int main()
{FILE* fp ;WCHAR wchar[5] = L"相等相等";        //定义一个宽字节的变量,初始为"相等"fp = fopen("1.txt", "w+");        //打开文件称奥做fwprintf(fp, L"%s\n", wchar);    //输出到文件fclose(fp);                        //关闭文件WCHAR wc2[5];                    //定义第二个宽字节变量//wc开始的有很多宽字节的操作。都和str相对应。wcscpy(wc2, wchar);                //复制。int n = wcscmp(wc2, wchar);        //比较if (n == 0){wprintf(L"相等\n");            //这里是否注意到没有wprintf有问题的。}char str[10];                    //定义char字符。n = wcstombs(str, wc2, 9);        //宽字节转换为muiltycharprintf("%s\n", str);            //输出结果for (int i = 0; i < 5; ++i){wc2[i] = L'1' + i;}wc2[4] = 0;n = wcstombs(str, wc2, 9);        //宽字节转换为muiltycharprintf("%s\n", str);            //输出结果//另外的方式转换n = WideCharToMultiByte(CP_ACP, NULL, wchar, wcslen(wchar) + 1, str, 10, 0, 0);printf("%s\n", str);char str2[10] = "加一";WCHAR wc3[10];n = MultiByteToWideChar(CP_ACP, NULL, str2, strlen(str2) + 1, wc3, 10);    //char到宽字节。system("pause");return 0;
}


from: http://www.cppblog.com/shongbee2/archive/2009/04/28/81349.html

这篇关于WCHAR的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/778327

相关文章

wchar_t, size_t 这些 xxx_t 类型在 C++ 中有哪些?都代表啥意思?

在C++(以及C)中,_t 后缀通常用于表示特定类型的数据,这些类型通常是在标准库中定义的,以便跨平台编程时提供一致性和可移植性。虽然并非所有以 _t 结尾的类型都是标准库的一部分(有些可能是特定平台或库的扩展),但以下是一些常见且标准库中的 _t 结尾的类型及其含义: size_t:这是一个无符号整数类型,用于表示对象的大小(如数组中的元素数量或结构体占用的字节数)。它的大小足以表示任何对象

MFC C++ BMP图片向右旋转90度示例函数 WCHAR与CHAR互转 CStringW CStringA互转

在MFC中,可以使用GDI+库来实现图像的旋转。以下是一个示例函数,展示如何将BMP图像向右旋转90度。首先,确保在项目中包含GDI+库,并在项目设置中添加#include <gdiplus.h>和#pragma comment(lib, "gdiplus.lib")。 #include <windows.h>#include <gdiplus.h>#pragma comment(lib,

mbs字符串(char*)与Unicode字符串(wchar_t*)的转换.md

一、C语言库函数 (1)setlocale() 功能:配置地域化信息;在输出Unicode字符串时会用到,在使用wcstombs函数时也会用到。下面英文描述中的用粗体字标出的函数都会用到该函数 头文件:< locale.h>; 函数原型: char *setlocale (int category, const char * locale); 函数参数: category 表示对本地

C++字符串(char/string/wchar_t/char16_t/char32_t)

示例:字符串abc转换成ab6 char name[] = "abc";name[2]=char(6+48);//48是ascii表中,char和int看起来相等的差值 C++中有五种方式可以表示字符串,记住前两种就可以 1.char类型的数组(C语言风格字符串) 2.string类(C++时代诞生的新类) 3.wchar_t宽字节型变量 4.char16_t 5.char32_t 1.

cstring转char*方法, 以及wchar转char方法

1.先说一下,cstring转char* 网上找到的方法如下: CString strFileRecord = "C:\haha.flv"; 强调一点,因为我是unicode编码,所以如下: WCHAR* wpFileName =(WCHAR*)m_strFileRecord.GetBuffer(m_strFileRecord.GetLength()); 这样出来的filename是完成

wchar to char转换

//将string转换成wstring wstring StringToWString(const string& str) { wstring result; //获取缓冲区大小,并申请空间,缓冲区大小按字符计算 int len = ::MultiByteToWideChar(CP_ACP, 0, str.c_str(), str.size(), NULL, 0);

c++Builder 2009 2010 出现Cannot convert 'wchar_t *' to 'const char *

Function(char * some) Function(edit->Text.c_str())  //结果就在这行出现Bug Cannot convert 'wchar_t *' to 'const char * 解决方法 菜单"Project"-》“Options”-》“Directories and Conditionals ”选项 _TCHAR maps to    ch

C++代码中的字符集问题:char和wchar_t

文章目录 字符集编码规则char和wchar_tchar处理中文时候的问题编码导致的问题wchar_t处理中文std::string和std::wstring 在前一篇的文章中,碰到的一个坑就是因为要躲开MFC中的一个CString类导致的各种问题。 话说回来,在C++的程序中,各种各样的字符类型处理也是一个比较麻烦的事情,特别是处理的文本里面有中文的时候。 在这个C++和

宽字符集操作函数_wchar_t 宽字符集 研究 和COM的 BSTR VARIANT

http://smycll.blog.hexun.com/80156767_d.html   宽字符集操作函数_wchar_t 宽字符集 研究 和COM的 BSTR VARIANT   wchar_t 是和 char 平等的地位,即 wchar_t 并非 typedef出来的,是原生的变量。 简单的说,它拥有两个字节,和short 占用空间一样。 比如: 字符串 "我们\n" ANSI

QT C++语言格式化输出wchar_t * 中文乱码

在 Qt 中,如果你使用 wprintf 或 wcout 进行宽字符输出,而且你的字符串包含中文字符,确保使用 Unicode 字符集,并将字符串编码为 UTF-16。此外,确保你的输出流和终端都能正确地处理宽字符。 下面是一个简单的例子: #include <QCoreApplication>#include <iostream>int main(int argc, char *argv[