5

我正在按照此代码进行修剪

    std::string tcp_read(int listen_at_port=8001){

    using namespace std;
    using namespace boost::algorithm;
    std::vector<char> received_data(512); 
    tcp_read(received_data, listen_at_port);
    string str1(received_data.begin(),received_data.end());
    trim_right(str1);
    return str1;
}

我单步执行了代码,我的 received_data 通常为 =“添加 8002(此处缓冲区填充有空格,直到 [511th] 位置)”

现在当我做 trim_right 时,我预计 str1 的大小会变成 8,但是当它返回时它仍然是 512,为什么?

我如何实际修剪并更改大小,以便字符串可以容纳到最后一个非空格字符

4

3 回答 3

2

正如另一个答案中所解释的那样,你vector的填充了零,它们不被视为空格,因此trim_right不会从字符串中删除它们。解决问题的一个简单方法是不使用向量的开始和结束迭代器构造字符串,而是使用string( char const * )构造函数。这也消除了对boost::trim_right.

std::string tcp_read(int listen_at_port=8001)
{
    using namespace std;

    std::vector<char> received_data(512); 
    tcp_read(received_data, listen_at_port);

    return string( received_data.data() );
    // or return string( &received_data[0] );
}
于 2013-05-25T18:13:27.690 回答
1

trim_right仅删除所有尾随空格。当您声明received_data它时,它被初始化为全零。当您从套接字读取数据时,缓冲区末尾的数据[肯定]不是由空格组成的。

我建议您在调用tcp_read()时返回实际从套接字读取的字节数,recieved_data.resize(byte_count);而不是调用trim_right. 此外,如果通过套接字接收的数据可以包含零,您可能应该返回 avector而不是string.

[感谢Praetorian指出它删除了所有空格]

于 2013-05-25T17:39:36.113 回答
0

这很愚蠢,但如果空格不是真正的空格:

string str1(received_data.begin(), 
    find(received_data.begin(), received_data.end(), received_data[511]) );

如果他们是:

string str1(received_data.begin(), 
    find( 
        find(received_data.begin(), received_data.end(), ' ') + 1, 
        received_data.end()) );

但这只是一些技巧,正确修剪应该可以正常工作,received_data 可能有问题。

是的,修剪字符串无论如何都不会重新分配任何内存,因此可以按原样存储它。

于 2013-05-25T18:16:46.853 回答