- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我想创建一个管理 istream 和 ostream 的类 (IOObj)。我坚持的部分是如何正确覆盖流运算符,以便给定 IOObj io {};
, io << "blah" << std::endl
使用 ostream 和 io >> x
输出使用 istream 输入到 x。我写的流操作符无法工作。 std::endl,可能还有大多数其他操纵器,都被简单地忽略了。
下面是我的尝试。
#ifndef IOOBJ_H_
#define IOOBJ_H_
#include <iostream>
#include "SimpleTextUIErrors.h"
namespace SimpleTextUI {
class IOObj: public std::iostream {
public:
IOObj(std::istream& in=std::cin, std::ostream& out=std::cout):
i{&in}, o{&out}, iOwner{false}, oOwner{false} {}
IOObj(std::istream& in, std::ostream* out): i{&in}, o{out}, iOwner{false}, oOwner{true} {}
IOObj(std::istream* in, std::ostream& out): i{in}, o{&out}, iOwner{true}, oOwner{false} {}
IOObj(std::istream* in, std::ostream* out): i{in}, o{out}, iOwner{true}, oOwner{true} {}
IOObj(const IOObj&)=delete;
IOObj& operator=(const IOObj&)=delete;
~IOObj() { releaseIO(); }
std::istream& in() { return *i; }
std::ostream& out() { return *o; }
void setInput(std::istream* in);
void setInput(std::istream& in);
void setOutput(std::ostream* out);
void setOutput(std::ostream& out);
void outputSeparator() { *o << "-------------------------------" << std::endl; }
protected:
IOObj(IOObj&&)=default;
IOObj& operator=(IOObj&&)=default;
private:
std::istream* i;
std::ostream* o;
bool iOwner, oOwner;
void releaseIO() {
releaseIn();
releaseOut();
}
void releaseIn() { if (iOwner) delete i; }
void releaseOut() { if (oOwner) delete o; }
};
template<typename T>
inline IOObj& operator<<(IOObj& io, T output) {
io.out() << output;
if (io.out().fail()) throw OutputFailedError{};
if (io.out().bad()) throw OutputBrokenError{};
return io;
}
template<typename T>
inline IOObj& operator>>(IOObj& io, T& input) {
io.in() >> input;
if (io.in().fail()) throw InputFailedError{};
if (io.in().bad()) throw InputBrokenError{};
return io;
}
} /* SimpleTextUI */
#endif /* IOOBJ_H_ */
最佳答案
诀窍是在操纵器的情况下也编写一个函数(比如 std::endl)。
我添加了以下代码:
inline IOObj& operator<<(IOObj& io, std::ostream& (*manip) (std::ostream&) ) {
io.out() << manip;
if (io.out().fail()) throw OutputFailedError{};
if (io.out().bad()) throw OutputBrokenError{};
return io;
}
不幸的是,这段代码与我代码中的<<模板函数完全一样,只是专门为流操纵器函数实例化。我无法解决这个问题(在下面发表评论,我会更新我的答案)。
此外,代码可能需要为 >> 运算符提供另一个这样的函数,但逻辑几乎相同。
关于C++:将 istream 和 ostream + 覆盖流运算符捆绑在一起,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32088464/
我正在开发一个小型图书馆,我需要做的一件事是让访问者访问一些数据并返回结果。 在一些较旧的 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
我是一名优秀的程序员,十分优秀!