CString的GetBuffer问题~

leo521 2009-08-18 01:27:27
代码如下:
CString m_sTrans;
BYTE *Byte;
int charnr = m_sTrans.GetLength();
Byte=(BYTE*)m_sTrans.GetBuffer(charnr); //cstring转BYTE
port.WriteToPort(Byte, m_sTrans.GetLength());

若m_sTrans为“654321”

为何Byte指针指向的第一个数是6 第二个成了0???
但是第三个又是5 第四个数又成了0.....这是为什么?~?怎么改呢??我希望Byte指针,依次指向6 5 4 3 2 1
不间隔一个0哦...
...全文
192 13 打赏 收藏 转发到动态 举报
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
leo521 2009-08-18
  • 打赏
  • 举报
回复
结贴给分~!~
skybblue 2009-08-18
  • 打赏
  • 举报
回复
WideCharToMultiByte Unicode转ASCII字符串
jasonM2008 2009-08-18
  • 打赏
  • 举报
回复
USES_CONVERSION;

Byte = W2A(m_Trans.GetBuffer());
I_NBFA 2009-08-18
  • 打赏
  • 举报
回复
我觉得大家还是注意ANSI和ASCII的区别,lz要的是ASC......
雪影 2009-08-18
  • 打赏
  • 举报
回复
例子 参考这个写
    wchar_t* wszString = L"abcd1234你我他";
//预转换,得到所需空间的大小,这次用的函数和上面名字相反
int ansiLen = ::WideCharToMultiByte(CP_ACP, NULL, wszString, wcslen(wszString), NULL, 0, NULL, NULL);
//同上,分配空间要给'\0'留个空间
char* szAnsi = new char[ansiLen + 1];
//转换
//unicode版对应的strlen是wcslen
::WideCharToMultiByte(CP_ACP, NULL, wszString, wcslen(wszString), szAnsi, ansiLen, NULL, NULL);
I_NBFA 2009-08-18
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 leo521 的回复:]
引用 3 楼 tttyd 的回复:
m_sTrans是两个字节的字符
你使用TCHAR试一试

将BYTE换成TCHAR

因为对方的借口就是一个BYTE的指针 所以我还是希望能直接给BYTE过去...

再问楼下 如何转换成ASC码呢?~
[/Quote]

(BYTE*)m_sTrans.GetBuffer(charnr)
这样就已经byte过去了啊, 如果charnr里含有非asc字符, 转不成asc, 转了也是乱码.
这关键要看对方是按什么编码的.
MoXiaoRab 2009-08-18
  • 打赏
  • 举报
回复
或者用W2A这个ATL的宏,更加方便的把Unicode转换成ANSI
雪影 2009-08-18
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 leo521 的回复:]
引用 3 楼 tttyd 的回复:
m_sTrans是两个字节的字符
你使用TCHAR试一试

将BYTE换成TCHAR

因为对方的借口就是一个BYTE的指针 所以我还是希望能直接给BYTE过去...

再问楼下 如何转换成ASC码呢?~
[/Quote]
WideCharToMultiByte
leo521 2009-08-18
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 tttyd 的回复:]
m_sTrans是两个字节的字符
你使用TCHAR试一试

将BYTE换成TCHAR
[/Quote]
因为对方的借口就是一个BYTE的指针 所以我还是希望能直接给BYTE过去...

再问楼下 如何转换成ASC码呢?~
vagrantisme 2009-08-18
  • 打赏
  • 举报
回复
你的是UNICODE编码,要先转换成ASC编码才能用GetBuffer。

同时建议不要用GetBuffer.如果忘记了释放就出现不可预知的东东。

建议用LPCTSTR直接转。
雪影 2009-08-18
  • 打赏
  • 举报
回复
m_sTrans是两个字节的字符
你使用TCHAR试一试

将BYTE换成TCHAR
skybblue 2009-08-18
  • 打赏
  • 举报
回复
字符串是以Unicode编码的,所以才会那样.unicode编码占用两个字节,对于英文字符,高字节为0
雪影 2009-08-18
  • 打赏
  • 举报
回复
UNICODE的问题?

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧