链表数据结构中的C++重载运算符>>
C++ overload Operator>> in Linked List Data Structure
我有一个链表
template<class T>
class Node<T>
{
typedef T elementType;
typedef Node<T>* position;
elementType _element;
position _next;
};
template <class T>
class LinkedList
{
public:
typedef Node<T>::position position;
typedef Node<T>::elementType elementType;
//operatori
bool empty() constprevious;
unsigned int size() constprevious; //convertire il tipo ritornato in unsigned int!! per tutte classi e metodi rilevanti **LEO**
elementType read(const position) constprevious;
void write(const position p, const elementType)previous;
void insert(const elementType)previous;
void insert(const position, const elementType)previous;
void delete(position)previous;
position first() constprevious;
position last() constprevious;
position next(position) constprevious;
position previous(position) constprevious;
void deleteAll();
private:
position _first;
position _last;
int _numElements;
};
template<class T>
istream &operator>> (istream &input, LinkedList<T> &linkedList )
{
//operator Code
return is;
}
**请注意:上面的代码可能不会编译,因为我修改了我的原始代码,这要长得多。不管怎样,既然我只需要一个如何进行的指示,那应该没问题
我想重载运算符>>,这样我就可以在代码中编写类似的东西
#include <cstdlib>
#include <iostream>
using namespace std;
//#include "LinkedList.h"
int main(int argc, char *argv[])
{
LinkedList linkedList;
cin>>linkedList; //<-- operator>> call.
system("PAUSE");
return EXIT_SUCCESS;
}
但是,如何实现>>运算符,使其独立于流类型(文件、键盘)?
我在谷歌上找不到任何关于这件事的信息。
C++输入流共享一个公共的基本istream
,因此,如果根据istream重载operator>>
,则该实现对每种类型的输入流都有效。
请检查类似问题的答案。它得到了充分的解释。
相关文章:
- 为什么比较运算符如此快速
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 增量运算符与后缀混淆
- 一个关于在C++中重载布尔运算符的问题
- 运算符C++ "delete []"仅删除 2 个前值
- 模板类无法识别友元运算符
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 关闭||运算符优化
- 通过继承类使用来自不同命名空间的运算符
- C++Cast运算符过载
- 如何使用AngelScript注册SFML Vector2运算符
- 重载元组索引运算符-C++
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- 布尔比较运算符是如何在C++中工作的
- 重载运算符new[]的行为取决于析构函数
- 是否需要使用 - &gt;运算符在C 中调用成员函数时