如何将_bstr_t转换为CString

问题描述 投票:10回答:5

我有一个_bstr_t变量bstrErr,我有一个CString变量csError。如何将bstrErr中的值设置为csError

c++ com mfc visual-c++ bstr
5个回答
16
投票

是不是只能施展它:

_bstr_t b("Steve");
CString cs;
cs = (LPCTSTR) b;

我认为这应该在项目是Unicode时起作用。


6
投票

CString具有LPCSTR和LPCWSTR的构造函数和赋值运算符,因此无需调用WideCharToMultiByte,并且无法在unicode或非unicode模式下获得转换错误。

你可以这样分配字符串:

csError = bstrErr.GetBSTR();

或者使用构造函数CString csError(bstrErr.GetBSTR());

我正在使用GetBSTR。这与使用(LPCWSTR)转换bstrErr是一回事,但我更喜欢它的易读性。


3
投票

如果为Unicode编译 - 只需将封装的BSTR分配给CString。如果为ANSI编译,则必须使用WideCharToMultiByte()进行转换。

还要注意封装的BSTR可以为null,这对应于空字符串。如果您不处理此问题,您的程序将遇到未定义的行为。


0
投票
BSTR myBSTRVal;
CString BSTRasCString("")
char  szValue[MAX_PATH] = "";

// This will map the BSTR to a new character string (szValue)
WideCharToMultiByte(CP_ACP, 0, myBSTRVal, -1, szValue, sizeof(szValue), NULL, 
NULL);
BSTRasCString.Format("%s", szValue);                
BSTRasCString.TrimLeft();
BSTRasCString.TrimRight();

0
投票

CStringTCStringCStringACStringW

  • CStringT是一个复杂的类模板,基于任意字符类型和帮助程序类模板,用于管理存储和功能。
  • CString是使用TCHAR字符类型的模板类的typedef。 TCHARis是一种通用类型,如果设置宏wchar,则解析为UNICODE,否则为char
  • CStringA是模板类的typedef,它在内部使用窄字符类型char
  • CStringW是模板类的typedef,它在内部使用宽字符类型wchar_t

我从不在代码中使用CString,而是总是使用显式类CStringACStringW。类CString*具有接受窄字符串和宽字符串的构造函数。 _bstr_t也是如此。 BSTR类型的字符串必须由函数SysAllocString()分配,该函数需要OLECHAR字符串,因此在Win32 / 64中是一个宽字符串。如果要将包含Unicode的_bstr_t复制到CStringA,则必须将其转换为UTF8。我使用类CW2ACA2W进行转换。

在以下Word加载项的事件函数中,我展示了这些类型的用法:

STDMETHODIMP CConnect::TestButtonClicked(IDispatch* Command)
{
  BSTR smi = SysAllocString(L"Two smileys 😊 in a row: ");
  _bstr_t ley = L"😊\U0001F60A";

  /* Either using CStringA, UTF16 -> UTF8 conversion needed */
  CStringA smiley(CW2A(smi, CP_UTF8));
  smiley += CW2A(ley.GetBSTR(), CP_UTF8);
  MessageBoxW(NULL, CA2W(smiley, CP_UTF8), L"Example", MB_OK | MB_TASKMODAL);

  /* Or using CStringW, use ctor and += operator directly
  CStringW smiley = smi;
  smiley += ley.GetBSTR();
  MessageBoxW(NULL, smiley, L"Example", MB_OK | MB_TASKMODAL);
  */

  SysFreeString(smi);

  return S_OK;
}
© www.soinside.com 2019 - 2024. All rights reserved.