Ich bin (vorwärts) über eine std :: map iterieren und würde gerne herausfinden, ob der Iterator auf das vorletzte Element zeigt. Ich kann nicht finden, wie man das überall macht.Überprüfen Sie, ob Iterator zu std :: Punkte auf zweitletztes Element mappen
Ich habe:
bool
isSecondLastFile(const TDateFileInfoMap::const_iterator &tsFile)
{
TDateFileInfoMap::reverse_iterator secondLastIt = mFileInfoMap.rbegin() + 1;
return (tsFile == secondLastIt);
}
Wo TDateFileInfoMap
ist std :: map
Ich erhalte:
error: no match for ‘operator==’ in ‘tsFile == secondLastIt’
/usr/lib/gcc/i686-redhat-linux/4.4.7/../../../../include/c++/4.4.7/bits/stl_tree.h:287: note: candidates are: bool std::_Rb_tree_const_iterator<_Tp>::operator==(const std::_Rb_tree_const_iterator<_Tp>&) const [with _Tp = std::pair<const long int, TFileInfo>]
Heißt das, ich kann nicht bedeuten, die vergleichen vorwärts und umgekehrter Iterator?
Wie finde ich heraus, ob der Vorwärtsiterator auf das zweitletzte Element zeigt?
Wie wäre es 'tsFile + 2 == mFileInfoMap.end()'? – lorro