CString::GetLength()获得字节数的正确方法

在Unicode编码的C++项目中,使用CString::GetLength()方法可能会导致字节数计算错误,特别是当字符串包含多字节字符如中文时。此问题在HTTP文件上传场景中尤为关键,因为错误的字节数可能导致上传文件不完整。解决方案包括将CString转换为CStringA以获取正确字节数,或者乘以sizeof(TCHAR)来适应Unicode环境。
摘要由CSDN通过智能技术生成

      前段时间,做http协议上传文件及断点续传控件时,在客户端采用C++调用CHttpConnection、CHttpFile进行文件上传。移植到Unicode编码时,上传得到的文件总是小于正常文件。最终发现问题出在CString::GetLength()方法上。当采用Unicode编码时,而且http header字符串中出现了中文或其其他多字节字符,该方法仍旧只返回字符数,而不是实际的字节数,这样在http header中的信息会比实际的少,导致http发送的数据小于预期的。

      按照MSDN的说吗,在选用MBCS多字节字符串编码时,该方法会得到正确的字节数。此时没有问题。

      For multibyte character sets (MBCS), GetLength counts each 8-bit character; that is, a lead and trail byte in one multibyte character are counted as two bytes.

      但是在Unicode编码下,一旦出现中文字符,该方法就会少统计。

      我试用最多的解决方法是:

      CString str("abc我");

      DWORD le0 = str.GetLength(); // 返回4,不是想要的字节数

      // 这样处理就对了。先用CStringA类转化成多字节字符串。

      le0 = CStringA(str).GetLength();

 

另外,也有人这样用,也可以。比上面效率高。

       DWORD le0 = str.GetLength() * sizeof(TCHAR);

// 这种用法在MBCS环境下可以省略。在Unicode下,所有字符(包括ascii及中文字符), 每个字符都被定义为WHAR, 即双字节Unicode字符。该方法也正确。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值