c++ - std::string::iterator 的 Linux 段错误

标签 c++ string sockets iterator segmentation-fault

我在 CentOS 6.4 64 位机器上的 libc.so.6 中不断出现异常段错误。这是 gdb 最常报告的回溯:

0x00007ffff60d9b3f in memcpy () from /lib64/libc.so.6
(gdb) backtrace
#0  0x00007ffff60d9b3f in memcpy () from /lib64/libc.so.6
#1  0x00000000004b6a6b in std::string::_S_construct<__gnu_cxx::__normal_iterator<char*, std::string> > ()
#2  0x00000000004b719b in NewsMAIL::SMTPClient::receiveLine(std::basic_string<char, std::char_traits<char>, std::allocator<char> >*) ()
#3  0x00000000004b776f in NewsMAIL::SMTPClient::handleResponse() ()

这是有问题的代码,似乎触发了段错误:

bool SMTPClient::receiveLine(std::string* Line)
{
    static std::string Buffer;
    std::string::iterator iter;

    while((iter = std::find(Buffer.begin(), Buffer.end(), '\n')) == Buffer.end()) {

        char Bucket[MAX_BUCKET_SIZE + 1] = {};
        int BytesRecv = read(m_Socket, Bucket, MAX_BUCKET_SIZE);

        //Did we get a socket error?
        if(BytesRecv == -1) {

            //This is generally considered a bad thing..
            *Line = Buffer;
            Buffer = std::string("");
            return false;
        }

        Bucket[BytesRecv] = 0;
        Buffer += Bucket;
    }

    *Line = std::string(Buffer.begin(), iter);
    Buffer = std::string(iter + 1, Buffer.end());

    return true;
}

有时它可以 100% 正常工作而不会出现任何故障,因此不幸的是,并非每次都如此。 上面的代码是这个的稍微修改的版本:https://stackoverflow.com/a/1584620/3133245

有没有人对为什么会发生这种情况有任何想法?我正在用 g++ 4.7.2 编译

谢谢!

内特

最佳答案

使用静态变量(Buffer)不是线程安全的。可能导致崩溃。

您应该添加一个检查以确保 Line 不是 NULL

顺便说一句,行 Buffer = std::string(""); 可以是 Buffer.clear();

关于c++ - std::string::iterator 的 Linux 段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20765609/

相关文章:

java - 如何用点格式化 double ?

python - UnicodeEncodeError - 在 Spyder 中有效,但从终端执行时无效

r - 使用字符串访问 data.table 列

c - TCP连接双方同时发送时丢包

mysql - Cloud SQL 代理错误 - 尝试以其访问权限禁止的方式访问套接字

c++ - 如何删除 map 实例?

c++ - 运算符-类的重载

c++ - 为什么选择 BSTR 以及如何将其转换为 QString?

c++ - C++继承中的静态指针

c - 使用可用端口号绑定(bind)套接字