我有一个_bstr_t
包含日语文本的字符串。我想将此字符串转换为定义为char *
.
我可以将_bstr_t
字符串转换为char *
(UTF-8) 字符串而不会丢失日文字符吗?
我有一个_bstr_t
包含日语文本的字符串。我想将此字符串转换为定义为char *
.
我可以将_bstr_t
字符串转换为char *
(UTF-8) 字符串而不会丢失日文字符吗?
使用 WideCharToMultiByte() – 传递 CP_UTF8 作为第一个参数。
请注意,BSTR 可以是空指针并且对应于空字符串 - 将此视为特殊情况。
这是一些应该进行转换的代码。
void PrintUtf8(const TCHAR* value) {
if (value == nullptr) {
printf("");
return;
}
int n = WideCharToMultiByte(CP_UTF8, 0, value, -1, nullptr, 0, nullptr, nullptr);
if (n <= 0) {
printf("");
return;
}
char* buffer = new char[n];
WideCharToMultiByte(CP_UTF8, 0, value, -1, buffer, n, nullptr, nullptr);
printf("%s", buffer);
delete(buffer);
}
这类事情非常方便的 MSDN 参考:http: //msdn.microsoft.com/en-us/library/ms235631 (VS.80).aspx
我认为你需要去 wchar_t* 因为 char* 会丢失 Unicode 的东西,虽然我不确定。
// convert_from_bstr_t.cpp
// compile with: /clr /link comsuppw.lib
#include <iostream>
#include <stdlib.h>
#include <string>
#include "atlbase.h"
#include "atlstr.h"
#include "comutil.h"
using namespace std;
using namespace System;
int main()
{
_bstr_t orig("Hello, World!");
wcout << orig << " (_bstr_t)" << endl;
// Convert to a char*
const size_t newsize = 100;
char nstring[newsize];
strcpy_s(nstring, (char *)orig);
strcat_s(nstring, " (char *)");
cout << nstring << endl;
// Convert to a wchar_t*
wchar_t wcstring[newsize];
wcscpy_s(wcstring, (wchar_t *)orig);
wcscat_s(wcstring, L" (wchar_t *)");
wcout << wcstring << endl;
// Convert to a CComBSTR
CComBSTR ccombstr((char *)orig);
if (ccombstr.Append(L" (CComBSTR)") == S_OK)
{
CW2A printstr(ccombstr);
cout << printstr << endl;
}
// Convert to a CString
CString cstring((char *)orig);
cstring += " (CString)";
cout << cstring << endl;
// Convert to a basic_string
string basicstring((char *)orig);
basicstring += " (basic_string)";
cout << basicstring << endl;
// Convert to a System::String
String ^systemstring = gcnew String((char *)orig);
systemstring += " (System::String)";
Console::WriteLine("{0}", systemstring);
delete systemstring;
}