如何在没有c ++副本的情况下从ostringstream获取char指针

时间:2013-06-19 16:56:46

标签: c++ ostringstream

我有一个包含一些数据的ostringstream变量。 我想设置一个指向ostringstream内部数据的char *指针。

如果我执行以下操作:

std::ostringstream ofs;
.....
const char *stam = (ofs.str()).c_str();

在ofs中有一个字符串内容的副本。 我希望在没有副本的情况下获得指向该内容的指针。

有办法吗?

2 个答案:

答案 0 :(得分:2)

这实际上回答了这个问题...花了一段时间,但我想这样做是出于同样的原因(效率与便携性对我的情况很好):

class mybuf : public std::stringbuf {
public:
    // expose the terribly named end/begin pointers
    char *eback() {
        return std::streambuf::eback();
    }
    char *pptr() {
        return std::streambuf::pptr();
    }
};


class myos : public std::ostringstream {
    mybuf d_buf;
public:
    myos() {
        // replace buffer
        std::basic_ostream<char>::rdbuf(&d_buf);
    }
    char *ptr();
};

char *myos::ptr() {
    // assert contiguous
    assert (  tellp() == (d_buf.pptr()-d_buf.eback()) );
    return d_buf.eback();
}

int main() {
    myos os;
    os << "hello";
    std::cout << "size: " << os.tellp()  << std::endl;
    std::string dat(os.ptr(),os.tellp());
    std::cout << "data: " << dat  << std::endl;
}

这再一次指出了标准库的深层次潜在问题 - 合同与安全性之间的混淆。在编写消息服务时,我需要一个有效合同的库...而不是安全。其他时候,在编写用户界面时,我需要强大的安全性 - 并且不太关心效率。

答案 1 :(得分:1)

虽然您无法获得指向ostringstream中字符缓冲区的指针,但是如果切换到使用stringstream,则可以访问其字符而无需复制它们。字符串流允许输入和输出(读取和写入流),而ostringstream仅允许输出(写入流)。例如:

std::stringstream ss;
ss << "This is a test.";

// Read stringstream from index 0.  Use different values to look at any character index.
ss.seekg(0);

char ch;
while (ss.get(ch)) {                  // loop getting single characters
    std::cout << ch;
}

ss.clear(); // Clear eof bit in case you want to read more from ss

This site对字符串流有很好的概述,以及你可以用它们做些什么。