gpt4 book ai didi

c++ - 无法重载自定义 PriorityQueue 的提取运算符

转载 作者:行者123 更新时间:2023-11-28 05:47:08 31 4
gpt4 key购买 nike

我正在尝试为我一直在编写的自定义 PriorityQueue 类重载 operator>>,代码如下:

/**
* @brief Overloaded stream extraction operator.
*
* Bitshift operator>>, i.e. extraction operator. Used to write data from an input stream
* into a targeted priority queue instance. The data is written into the queue in the format,
*
* \verbatim
[item1] + "\t" + [priority1] + "\n"
[item2] + "\t" + [priority2] + "\n"
...
* \endverbatim
*
* @todo Implement functionality for any generic Type and PriorityType.
* @warning Only works for primitives as template types currently!
* @param inStream Reference to input stream
* @param targetQueue Instance of priority queue to manipulate with extraction stream
* @return Reference to input stream containing target queue data
*/
template<typename Type, typename PriorityType> std::istream& operator>>(std::istream& inStream, PriorityQueue<Type, PriorityType>& targetQueue) {

// vector container for input storage
std::vector< std::pair<Type, PriorityType> > pairVec;
// cache to store line input from stream
std::string input;

std::getline(inStream, input);

if (typeid(inStream) == typeid(std::ifstream)) {
inStream.ignore(std::numeric_limits<std::streamsize>::max(), '\n');
}

// loop until empty line
while (!input.empty()) {
unsigned int first = 0;
// loop over input cache
for (unsigned int i = 0; i < input.size(); ++i) {
// if char at index i of cache is a tab, break from loop
if (input.at(i) == '\t')
break;
++first;
}
std::string data_str = input.substr(0, first);
// convert from std::string to reqd Type
Type data = atoi(data_str.c_str());

std::string priority_str = input.substr(first);
// convert from std::string to reqd PriorityType
PriorityType priority = atof(priority_str.c_str());

pairVec.push_back(std::make_pair(data, priority));

// get line from input stream and store in input string
std::getline(inStream, input);
}

// enqueue pairVec container into targetQueue
//targetQueue.enqueueWithPriority(pairVec);

return inStream;

}

这目前适用于 stdinstd::cin 输入,但它不适用于 fstream 输入 - 第一个 getline 总是从输入中读取一个空行,这样 while 循环永远不会被触发,而且我似乎无法跳过它(我尝试使用 inStream.ignore( ) 正如您在上面看到的,但这不起作用。

编辑:

目前我只想让它为文件输入工作而忽略了它现在仅适用于 int 数据类型和 double 优先级类型的事实——这些不相关(targetQueue 对象本身的实际操作也不是)。

目前我只关心解决尝试通过文件输入流式传输时的空行问题。

要传递的示例文件:

3    5.6
2 6.3
1 56.7
12 45.1

每行的数字以 \t 分隔。

示例测试:

#include "PriorityQueue.h"
#include <sstream>
#include <iostream>
#include <fstream>

int main(void) {

// create pq of MAX binary heap type
PriorityQueue<int, double> pq(MAX);


std::ifstream file("test.txt");

file >> pq;

std::cout << pq;

}

其中“test.txt”是上述示例文件的格式。

编辑:更简单的示例

代码:

#include <iostream>
#include <fstream>
#include <vector>

class Example {

public:

Example() {}

size_t getSize() const { return vec.size(); }

friend std::istream& operator>>(std::istream& is, Example& example);

private:

std::vector< std::pair<int, double> > vec;

};

std::istream& operator>>(std::istream& is, Example& example) {

int x;
double y;
while (is >> x >> y) {
std::cout << "in-loop" << std::endl;
example.vec.push_back(std::make_pair(x, y));
}
return is;
}

int main(void) {

Example example;

std::ifstream file("test.txt");

file >> example;

file.close();

std::cout << example.getSize() << std::endl;

return 0;

}

最佳答案

对于许多类型,运算符已经重载——并且应该重载。让这些函数完成它们的工作:

template<typename Type, typename PriorityType>
std::istream& operator>>(std::istream& inStream, PriorityQueue<Type, PriorityType>& targetQueue)
{
std::vector< std::pair<Type, PriorityType> > pairVec;
Type data;
PriorityType priority;

while(inStream >> data >> priority)
pairVec.push_back(std::make_pair(data, priority));

targetQueue.enqueueWithPriority(pairVec);

return inStream;
}

关于c++ - 无法重载自定义 PriorityQueue 的提取运算符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35997152/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com