不确定是什么导致我的插入过载混乱
好吧,所以在我的主要内容中,当我尝试使用重载的 << 打印集合时插入运算符我收到一条错误消息,错误:与“operator<<”不匹配在 'std::cout << person_list',然后它继续给我一个巨大的候选人名单,我认为这些候选人实际上可以工作。有趣的是,main 中的 for 循环将打印出我期望插入重载如何打印的集合。我也已经有了一个 person 结构的重载。有什么想法吗?
这是我到目前为止所拥有的:
#include <iostream>
#include <string>
#include <iterator>
#include <algorithm>
#include "personDirectory.h"
using namespace std;
void person_directory::addPerson(const person& p){
people.push_back(p);
idMap.insert(pair<int,person*>(p.id, const_cast<person*>(&p)));
phoneMap.insert(pair<int,person*>(p.phoneNumber, const_cast<person*>(&p)));
ageMap.insert(pair<int,person*>(p.age, const_cast<person*>(&p)));
nameMap.insert(pair<string,person*>(p.name, const_cast<person*>(&p)));
cout << "*******************" << endl << endl;
cout << "Person: " << endl;
cout << p;
cout << "was added" << endl;
cout << "*******************" << endl;
}
set<person*> person_directory::findByName(string fn){
//maybe construct a set using the constructor with
//iterator from beginning of map to end of map
set<person*> temp;
for(multimap<string, person*>::const_iterator it = nameMap.begin();
it != nameMap.end();){
if(it->first == fn)
temp.insert(it->second);
it++;
}
return temp;
}
ostream& operator<<(ostream& out,const set<person*>& s){
out << "Your set: " << endl;
for(set<person*>::const_iterator it = s.begin(); it != s.end(); ++it){
out << **it;
}
return out;
}
这是主要内容:
#include <iostream>
#include <vector>
#include "person.h"
#include "personDirectory.h"
using namespace std;
int main(){
//testing person
person* p1 = new person(1, "Carl Jr", 36, 4563456);
person* p2 = new person(2, "Indiana Jones", 24, 6782345);
person* p3 = new person(3, "Bobby Boy", 23, 6782275);
person* p4 = new person(4, "Robby", 19, 6782234);
person* p5 = new person(5, "Carl Sagan", 47, 4562234);
person* p6 = new person(6, "Bobby Boy", 11, 6786657);
person_directory* person_dir = new person_directory();
person_dir->addPerson(*p1);
person_dir->addPerson(*p2);
person_dir->addPerson(*p3);
person_dir->addPerson(*p4);
person_dir->addPerson(*p5);
person_dir->addPerson(*p6);
set<person*> person_list;
person_list = person_dir->findByName("Bobby Boy");
cout << person_list;
for(set<person*>::const_iterator it = person_list.begin(); it != person_list.end(); ++it){
cout << **it;
}
}
这是我猜的最后一个相关部分:
#ifndef _PERSON_DIRECTORY_H_
#define _PERSON_DIRECTORY_H_
#include "person.h"
#include <map>
#include <set>
#include <vector>
using std::map;
using std::set;
using std::vector;
using std::multimap;
class person_directory {
private:
// this vector will contain the actual data
vector<person> people;
// this maps serve as indexes; they contain pointers to the data in people
map<int,person*> idMap;
multimap<int,person*> phoneMap, ageMap;
multimap<string,person*> nameMap;
public:
void addPerson(const person& p);
set<person*> findByName(string fn);
person* findById(int id);
set<person*> findByAge(int age);
set<person*> findByPhone(int p);
friend std::ostream& operator<<(std::ostream& out, const std::set<person*>& s);
};
#endif
Okay, so in my main, when I try to print out the set using the overloaded << insertion operator I get an error saying, error: no match for 'operator<<' in 'std::cout << person_list' and then it goes on to give me an enormous list of candidates that would actually work I suppose. What's interesting is that the for loop in main will print out the set how I would expect the insertion overload to print out.. I also already have a overload for a person struct already.. Any ideas?
Here's what I have so far:
#include <iostream>
#include <string>
#include <iterator>
#include <algorithm>
#include "personDirectory.h"
using namespace std;
void person_directory::addPerson(const person& p){
people.push_back(p);
idMap.insert(pair<int,person*>(p.id, const_cast<person*>(&p)));
phoneMap.insert(pair<int,person*>(p.phoneNumber, const_cast<person*>(&p)));
ageMap.insert(pair<int,person*>(p.age, const_cast<person*>(&p)));
nameMap.insert(pair<string,person*>(p.name, const_cast<person*>(&p)));
cout << "*******************" << endl << endl;
cout << "Person: " << endl;
cout << p;
cout << "was added" << endl;
cout << "*******************" << endl;
}
set<person*> person_directory::findByName(string fn){
//maybe construct a set using the constructor with
//iterator from beginning of map to end of map
set<person*> temp;
for(multimap<string, person*>::const_iterator it = nameMap.begin();
it != nameMap.end();){
if(it->first == fn)
temp.insert(it->second);
it++;
}
return temp;
}
ostream& operator<<(ostream& out,const set<person*>& s){
out << "Your set: " << endl;
for(set<person*>::const_iterator it = s.begin(); it != s.end(); ++it){
out << **it;
}
return out;
}
Here's the main:
#include <iostream>
#include <vector>
#include "person.h"
#include "personDirectory.h"
using namespace std;
int main(){
//testing person
person* p1 = new person(1, "Carl Jr", 36, 4563456);
person* p2 = new person(2, "Indiana Jones", 24, 6782345);
person* p3 = new person(3, "Bobby Boy", 23, 6782275);
person* p4 = new person(4, "Robby", 19, 6782234);
person* p5 = new person(5, "Carl Sagan", 47, 4562234);
person* p6 = new person(6, "Bobby Boy", 11, 6786657);
person_directory* person_dir = new person_directory();
person_dir->addPerson(*p1);
person_dir->addPerson(*p2);
person_dir->addPerson(*p3);
person_dir->addPerson(*p4);
person_dir->addPerson(*p5);
person_dir->addPerson(*p6);
set<person*> person_list;
person_list = person_dir->findByName("Bobby Boy");
cout << person_list;
for(set<person*>::const_iterator it = person_list.begin(); it != person_list.end(); ++it){
cout << **it;
}
}
Here's the last relevant part I guess:
#ifndef _PERSON_DIRECTORY_H_
#define _PERSON_DIRECTORY_H_
#include "person.h"
#include <map>
#include <set>
#include <vector>
using std::map;
using std::set;
using std::vector;
using std::multimap;
class person_directory {
private:
// this vector will contain the actual data
vector<person> people;
// this maps serve as indexes; they contain pointers to the data in people
map<int,person*> idMap;
multimap<int,person*> phoneMap, ageMap;
multimap<string,person*> nameMap;
public:
void addPerson(const person& p);
set<person*> findByName(string fn);
person* findById(int id);
set<person*> findByAge(int age);
set<person*> findByPhone(int p);
friend std::ostream& operator<<(std::ostream& out, const std::set<person*>& s);
};
#endif
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
您是否有运营商的前向声明<<在你的标题中(personDirectory.hi 假设)?即:
如果你没有,你就需要一个。
注意:据我所知,好友声明还不够。
Do you have a forward declaration for the operator<< in your header (personDirectory.h i assume)? i.e:
If you don't, you need one.
Note: the friend declaration isn't enough afaik.
您有集合的运算符重载,但缺少人员的运算符重载!
它看起来像这样:
ostream&运算符<<(ostream&out, const person&p)
{
// 待办事项......
}
you have operator overload for set, but operator overload for person is missing!
it will look like this:
ostream& operator<<(ostream& out, const person& p)
{
// TODO......
}