为什么我的消息框显示为另一种语言?
Why Does my Message Box Show Up in Another Language?
老实说,我现在快疯了。让我先说 "MessageBox" 函数在我定义其中的文本时在 CodeBlocks 中工作得很好;但无论出于何种原因,Visual Studio 对 MessageBox 函数中的内容非常挑剔。
它一直告诉我无论我放入其中的什么对 LPCWSTR "thing" 都是无效的。为了避免这种情况,我在下面编写了这个东西:
int main()
{
LPCWSTR a;
std::string s = "Please help me.";
a = (LPCWSTR)s.c_str();
LPCWSTR b;
std::string t = "MTS";
b = (LPCWSTR)t.c_str();
MessageBox(0,a,b, MB_OK | MB_ICONSTOP);
}
它并没有像我最初想象的那样工作,结果我得到了这个:
这对我来说压力很大,我知道之前在这里已经被问过一次,所以请不要将我的问题标记为重复。我如何使此代码起作用,以便我的消息以英语显示并清楚地描述我想说的内容?
提前致谢,
MTS
它以另一种语言显示的原因(通常,它在您看到的语言中是乱码)是因为您正在转换字符串类型而不是使用正确的字符串类型:
LPCWSTR b;
std::string t = "MTS";
b = (LPCWSTR)t.c_str();
此代码不会将基于 ANSI 的窄字符串转换为宽字符串。转换 不会 转换字符串类型。如果你删除了转换,你会看到编译器给你一个字符串类型/指针不匹配的错误。
由于您使用的是 MessageBox
函数,这实际上是对 MessageBoxW
的调用,它需要宽字符串参数。
在你的情况下调用 MessageBoxW
的原因是 MessageBox
将是 MessageBoxA
或 MessageBoxW
,具体取决于构建类型(MBCS
或 Unicode
)。对于 CodeBlocks,您可能将项目设置为 MBCS
,而在 Visual Studio 上,它设置为 Unicode
,因此它适用于一个项目,但在另一个项目上失败。
因此,解决方法是在这种情况下提供宽字符串:
LPCWSTR b;
std::wstring t = L"MTS";
b = t.c_str();
甚至这样:
LPCWSTR b;
std::basic_string<WCHAR> t = L"MTS";
b = t.c_str();
如果您希望在 MBCS
和 Unicode
构建中使用相同的代码而不更改代码,那么也可以使用以下代码:
#include <tchar.h>
//...
LPCTSTR b;
std::basic_string<TCHAR> t = _T("MTS");
b = t.c_str();
这使用 _T
(或 TEXT
宏)使字符串文字变窄或变宽,具体取决于构建类型。 TCHAR
将变窄或变宽,具体取决于构建类型。
底线是这样的——如果您正在调用一个需要字符串的函数,而编译器给您一个字符串类型不匹配的错误,请执行 not 尝试 C 风格的转换以 "fix" 编译器错误。字符串尤其如此。相反,
1) 提供正确的字符串类型,这样就永远不需要转换,
或
2) 调用正确的函数(在本例中为 MessageBoxA
),该函数无需应用强制转换即可接受您的字符串类型。
老实说,我现在快疯了。让我先说 "MessageBox" 函数在我定义其中的文本时在 CodeBlocks 中工作得很好;但无论出于何种原因,Visual Studio 对 MessageBox 函数中的内容非常挑剔。
它一直告诉我无论我放入其中的什么对 LPCWSTR "thing" 都是无效的。为了避免这种情况,我在下面编写了这个东西:
int main()
{
LPCWSTR a;
std::string s = "Please help me.";
a = (LPCWSTR)s.c_str();
LPCWSTR b;
std::string t = "MTS";
b = (LPCWSTR)t.c_str();
MessageBox(0,a,b, MB_OK | MB_ICONSTOP);
}
它并没有像我最初想象的那样工作,结果我得到了这个:
这对我来说压力很大,我知道之前在这里已经被问过一次,所以请不要将我的问题标记为重复。我如何使此代码起作用,以便我的消息以英语显示并清楚地描述我想说的内容?
提前致谢,
MTS
它以另一种语言显示的原因(通常,它在您看到的语言中是乱码)是因为您正在转换字符串类型而不是使用正确的字符串类型:
LPCWSTR b;
std::string t = "MTS";
b = (LPCWSTR)t.c_str();
此代码不会将基于 ANSI 的窄字符串转换为宽字符串。转换 不会 转换字符串类型。如果你删除了转换,你会看到编译器给你一个字符串类型/指针不匹配的错误。
由于您使用的是 MessageBox
函数,这实际上是对 MessageBoxW
的调用,它需要宽字符串参数。
在你的情况下调用 MessageBoxW
的原因是 MessageBox
将是 MessageBoxA
或 MessageBoxW
,具体取决于构建类型(MBCS
或 Unicode
)。对于 CodeBlocks,您可能将项目设置为 MBCS
,而在 Visual Studio 上,它设置为 Unicode
,因此它适用于一个项目,但在另一个项目上失败。
因此,解决方法是在这种情况下提供宽字符串:
LPCWSTR b;
std::wstring t = L"MTS";
b = t.c_str();
甚至这样:
LPCWSTR b;
std::basic_string<WCHAR> t = L"MTS";
b = t.c_str();
如果您希望在 MBCS
和 Unicode
构建中使用相同的代码而不更改代码,那么也可以使用以下代码:
#include <tchar.h>
//...
LPCTSTR b;
std::basic_string<TCHAR> t = _T("MTS");
b = t.c_str();
这使用 _T
(或 TEXT
宏)使字符串文字变窄或变宽,具体取决于构建类型。 TCHAR
将变窄或变宽,具体取决于构建类型。
底线是这样的——如果您正在调用一个需要字符串的函数,而编译器给您一个字符串类型不匹配的错误,请执行 not 尝试 C 风格的转换以 "fix" 编译器错误。字符串尤其如此。相反,
1) 提供正确的字符串类型,这样就永远不需要转换,
或
2) 调用正确的函数(在本例中为 MessageBoxA
),该函数无需应用强制转换即可接受您的字符串类型。