我有一个带有“数组数组”私有成员的类,表示为:
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;
}