我有一个带有“数组数组”私有成员的类,表示为:
std::deque<std::deque<SomeClass> > someArray_;
这个类也有一个公共方法,它允许接收所有唯一的SomeClass实例,包含在someArray_. 实例的唯一SomeClass性意味着多个类成员中的至少一个不同。我决定std::set为此目的使用。该方法的原型如下:
std::set<SomeClass> getAllUniqueInstances() const;
在此方法实现中,我使用以下构造来填充std::set:
std::set<SomeClass> allUniqueInstances;
for(auto it = std::begin(someArray_); it != std::end(someArray_); ++it){
std::copy((*it).begin(),
(*it).end(),
std::inserter(allUniqueInstances, allUniqueInstances.end()));
}
operator<()为SomeClass类定义。结果 mystd::set被填充了,但是大量的实例被遗漏了。修改operator<()类SomeClass,改变情况,但破坏了理想的排序顺序。在这种情况下如何std::copy确定相当大的实例是否是唯一的?
UPD:源代码SomeClass
class SomeClass{
private:
uint32_t from_;
uint32_t to_;
double capacity_;
double flow_;
public:
...
bool operator<(const SomeClass& rhs) const;
...
};
我希望SomeClass实例按from_成员排序:
bool SomeClass::operator<( const SomeClass& rhs ) const{
if(this->from_ < rhs.from_)
return true;
return false;
}