4
这是我的课使用函数指针
template <typename TValue, typename TPred = std::less<TValue> >
class BinarySearchTree {
public:
BinarySearchTree<TValue, TPred> &operator=(BinarySearchTree<TValue, TPred> const &tree) {
if (this != &tree) {
tree.VisitInOrder(Insert);
}
return *this;
}
bool Insert(TValue const &value) {
return m_Insert(value, pRoot);
}
template <typename TVisitor> void VisitInOrder(TVisitor visitor) const;
...
};
的选择,并按照以下顺序不会工作:VisitInOrder(Insert)
,因为我的编译器说有争论缺少
,但我的主要看起来像这样在那里我可以使用函数没有它的参数:
void Print(int const x) { cout << x << endl; }
int main() {
BinarySearchTree<int> obj1, obj2, obj3;
obj1.Insert(10);
obj1.VisitInOrder(Print);
return 0;
}
完整的代码在这里:http://pastebin.com/TJmAgwdu
@Praetorian:哎呀: )编辑,谢谢! –
感谢,伟大的作品 – schreda
@schreda:很高兴帮助 –