在这个函数中,将string
作为参数传递(将大量数据作为字符串)...
SendBytes方法定义如下
bool NetOutputBuffer_c::SendBytes ( const void * pBuf, int iLen )
{
BYTE * pMy = (BYTE*)pBuf;
while ( iLen>0 && !m_bError )
{
int iLeft = m_iBufferSize - ( m_pBufferPtr-m_pBuffer );
if ( iLen<=iLeft )
{
printf("iLen is %d\n",iLen);
memcpy ( m_pBufferPtr, pMy, iLen );
m_pBufferPtr += iLen;
break;
}
ResizeIf ( iLen );
}
return !m_bError;
}
bool NetOutputBuffer_c::SendCompressedString ( std::string sStr )
{
std::cout << sStr << endl;
const char *cStr = sStr.c_str();
std::cout << cStr <<endl;
int iLen = cStr ? strlen(cStr) : 0;
SendInt ( iLen );
return SendBytes ( cStr, iLen );
}
尝试打印sStr的值以检查它是否具有正确的数据。
然后将std::string
转换为const char *
转换后,尝试打印cStr的值。但它(cStr)实际上包含5%的实际数据(sStr)...
我需要做什么才能获得整个数据?
有人可以在这方面指导我吗?
答案 0 :(得分:4)
strlen
适用于c字符串。也就是说,以null结尾的字符串。它搜索'\0'
字符,并将该字符的位置作为字符串的长度返回。您有压缩的二进制数据,而不是c字符串。它几乎肯定在字符串结尾之前包含一个0。请改用sStr.size()
。
SendInt ( sStr.size() );
return SendBytes ( sStr.c_str(), sStr.size() );