我有一个包含一些数据的ostringstream变量。 我想设置一个指向ostringstream内部数据的char *指针。
如果我执行以下操作:
std::ostringstream ofs;
.....
const char *stam = (ofs.str()).c_str();
在ofs中有一个字符串内容的副本。 我希望在没有副本的情况下获得指向该内容的指针。
有办法吗?
答案 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对字符串流有很好的概述,以及你可以用它们做些什么。