- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
为什么我不能像这样为我的输出创建一个“空”流
std::ostream out;
?
这行显然是非法的 clang 3.4
和 gcc 4.8.1
在 linux 下使用 libstdc++
,我真的不明白为什么,我的意思是为什么我不能随便创建一个流并像我想要的那样使用它?请注意, std::ofstream out;
是 100% 可以的。我只是不明白这背后的逻辑。如果您考虑到在创建之后我可以使用这个缓冲区并与其他缓冲区共享一个公共(public)缓冲区,那就更奇怪了 copyfmt
所以我的 std::ostream
从创建对象开始就被初始化为有用的东西。
请不要偏离这一点,我不需要 stringstreams
,我需要 ios
流,因为我必须做的事情以及方法和他们提供的属性。
最佳答案
我承认我也不明白。我找不到任何std::istream
的默认构造函数,我认为如果你想创建一个双向流,你会想要一个,因为 std::ios_base
的工作方式很奇怪:构造函数不初始化任何东西,但派生的类必须在其中显式调用 std::ios_base::init
构造函数。当涉及多重继承时(即双向 IO,其中类派生自两者std::istream
和 std::ostream
),我只希望派生类调用 std::ios_base::init
。 (在std::iostream
, std::ios_base::init
将被调用两次。)事实上,在标准中查找之前,我正要回答默认构造函数受到保护,因为它没有调用std::ios_base::init
,而是直接使用比在派生类中,会导致未初始化流。
不管怎样,你眼前的问题有一个简单的解决方案:
std::ostream out( NULL );
另外:您稍后需要设置其接收器的功能是rdbuf()
的非 const 版本,而不是 copyfmt()
。 rdbuf()
是用于读取和设置指向 streambuf
的指针,copyfmt()
复制格式标志,但 not 触摸指向 streambuf
的指针。
所以你可以这样做:
std::ostream out( NULL );
// ...
std::filebuf fileBuffer;
if ( filenameGiven ) {
fileBuffer.open( filename.c_str(), std::ios_base::out );
}
if ( fileIsOpen() ) {
out.rdbuf( &fileBuffer );
} else {
out.rdbuf( std::cout.rdbuf() );
}
(我经常这样做。其实我以为是平常的事先不知道是否输出到文件时的习惯用法或 std::cout
。)
编辑:
还有一个更正:rdbuf
的非常量版本调用 clear()
,所以你不必。 (我知道我没有调用 clear()
就做到了,但是当我看到 init
设置 badbit
...)
无论如何:总结是:通常最好将指针传递给有效的streambuf 到 std::ostream
的构造函数,但如果你不能,那就是传递一个空指针是完全有效的,稍后使用rdbuf()
。否则的答案是完全错误的。
关于c++ - 为什么 std::ostream 的构造函数受到保护?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18031357/
我正在开发一个小型图书馆,我需要做的一件事是让访问者访问一些数据并返回结果。 在一些较旧的 C++ 代码中,访问者需要声明一个 typedef return_type .例如,boost::stati
我不明白这个 ostream 函数声明是什么意思: ostream& operator<< (ostream& (*pf)(ostream&)); (特别是 (*pf)(ostream&) 部分)。我
我正在寻找一种将内容从一个 ostream 复制到另一个的方法。我有以下代码: std::ostringsteam oss; oss << "stack overflow"; { //do s
我有一个装满小雕像的游戏板。 分配: board = new Figure*[boardSize]; for (int i = 0; i > > board(boardSize, vector>(b
代码: cout SomeStream &operator SomeStream &operator (*this) << val; //Trouble in there! std::co
我正在对我的项目进行一些类型检查。下面的例子 using namespace std; cout ::value ? "TRUE":"FALSE" ) (); } 格式正确(source)。 std:
我到处搜索,但没有找到答案,所以如果这是重复的,请原谅。 我有一些非常古老的 C++ 代码,我正试图将它们轻松地转换为这个千年。代码仍然在 Visual Studio 6 中编译并且需要继续这样做,但
在我的 C++ 代码中,我不断地将不同的值写入文件。我的问题是,考虑到文件已成功打开这一事实,如果在任何情况下 write 或 << 会失败。我是否需要检查每次调用 write 或 << 以确保它已正
这个问题在这里已经有了答案: Calling a function overloaded in several namespaces from inside one namespace (3 个答案
我只是在写一些代码来吐出一个 wave header。我开始输入: file > 运算符?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com
我有一个派生自 std::ostream 的类(用于日志记录)。剥离下来,它看起来像这样: class bsgs : public std::ostream { public: bsgs(cons
我有以下代码: class A { public: ... C *func() { ... } void func2() { ... } ... }; class B
我在一个抽象类的头文件中找到了这个函数: virtual ostream & print( ostream & out ) const; 谁能告诉我这是什么函数以及如何在派生类中声明它?据我所知,它似
我想写一个函数输出一些东西到 ostream传入并返回流,如下所示: std::ostream& MyPrint(int val, std::ostream* out) { *out << val
偶尔我会写一个类(T 说)并尝试覆盖 std::ostream& operator<<(std::ostream&, const T&) 但它不适用于某些类。这是一个(简化的)类的示例,它对我不起作用
我一直在尝试创建一个程序来为一组已定义的进程实现实时调度算法。使用 g++ 编译时出现错误,其中指出: RTSprocess.h:在函数“std::ostream& operator #include
因此,我得到了一个带有起始代码的任务来实现一个链表(我已经成功地完成了一个未排序的双向链表)并且在给定头文件的起始代码中有一个友元声明似乎有允许我使用 cout 打印链表的目标陈述。这是头文件;请注意
我正在努力 cout using namespace std; ostream& Print(ostream& out) { out using namespace std; ostream&
为了序列化任何对象(即对于没有全局 ostream& operator std::ostream& operator std::string serialize_any(const T& val) {
我宁愿实现一个non-friend函数,直接将函数标记为virtual。 但我现在想确保一组特定的类实现重载 friend std::ostream& operator << (std::ostrea
我是一名优秀的程序员,十分优秀!