我正在使用Visual Studio c ++并希望将Cstring转换为Byte。我已经编写了这段代码,但它在第二行中给出了错误,即“数据”未定义。
CString data = _T( "OK");
LPBYTE pByte = new BYTE[data.GetLength() + 1];
memcpy(pByte, (VOID*)LPCTSTR(data), data.GetLength());
此外,我需要将LPBYTE转换为const char以用于strcmp函数。我写了代码,但我找不到它的问题。
const LPBYTE lpBuffer;
LPBYTE lpData = lpBuffer;
CString rcvValue(LPCSTR(lpBuffer));
const CHAR* cstr = (LPCSTR)rcvValue;
if (strcmp (cstr,("ABC")) == 0)
{
////
}
答案 0 :(得分:3)
CString
类型是CStringT的模板特殊化,具体取决于其使用的字符集(ANSI为CStringA
,Unicode为CStringW
)。通过使用_T macro从字符串文字构造时,虽然可以确保使用匹配的编码,但是在将受控序列复制到缓冲区时,您并没有考虑到不同的大小要求。
以下代码修复了第一部分:
CString data = _T("OK");
size_t size_in_bytes = (data.GetLength() + 1) * sizeof(data::XCHAR);
std::vector<BYTE> buffer(size_in_bytes);
unsigned char const* first = static_cast<unsigned char*>(data.GetString());
unsigned char const* last = first + size_in_bytes;
std::copy(first, last, buffer.begin());
第二个问题确实是要解决已解决的问题。 CStringT
类型已经提供了一个CStringT::Compare成员,可以使用:
const LPBYTE lpBuffer;
CString rcvValue(static_cast<char const*>(lpBuffer));
if (rcvValue.Compare(_T("ABC")) == 0)
{
////
}
一般建议:始终喜欢使用与您的字符编码(即CStringT
或CStringA
)相匹配的具体CStringW
专业名称。该代码将更易于阅读和说明,当您遇到需要帮助的问题时,可以在Stack Overflow上发布问题,而无需解释正在使用的编译器设置。
答案 1 :(得分:1)
确保包含atlstr.h以提供CString的定义,如下所示:
#include "stdafx.h"
#include <Windows.h>
#include <atlstr.h>
int _tmain(int argc, _TCHAR* argv[])
{
CString data = _T( "OK");
LPBYTE pByte = new BYTE[data.GetLength() + 1];
memcpy(pByte, (VOID*)LPCTSTR(data), data.GetLength());
return 0;
}
答案 2 :(得分:1)
我相当肯定Jay对你的第一个问题是正确的。您需要包含正确的标题。
对于您的第二个问题,为什么您希望该代码有效?让我们来看看你写的代码实际上是做什么的。
请记住CString包含随机垃圾,您希望这段代码到底做什么? (除了可怕的崩溃?=))
我还想指出,你需要在你的字符串方法中更加一致。您是否计划支持基于char和wchar_t的字符串,因为您在第一部分中建议使用TCHAR?你想使用C-Style字符串还是想使用像CString这样的对象?如果你想使用CString,只需使用CString提供的Compare函数。不要打扰strcmp。
答案 3 :(得分:-1)
可能你没有包含该标题
#include <afx.h>
int main()
{
CString data = _T( "OK");
LPBYTE pByte = new BYTE[data.GetLength() + 1];
memcpy(pByte, (VOID*)LPCTSTR(data), data.GetLength());
return 0;
}
此代码工作正常。
答案 4 :(得分:-1)
你应该使用
CString ss = "123ABC";
BYTE* bp = (BYTE*)ss.GetBuffer(ss.GetLength());
BYTE expected[16] ;
CopyMemory(expected,bp,sizeof(expected));
只使用'='将无效。