在C++中,實現(xiàn)一個自定義的visit
函數(shù)可以通過模板和重載技術(shù)來完成。這里是一個簡單的例子,展示了如何創(chuàng)建一個visit
函數(shù),它可以接受不同類型的參數(shù)并根據(jù)參數(shù)類型執(zhí)行相應(yīng)的操作。
#include<iostream>
#include<string>
// 定義一個基類,用于多態(tài)
class Animal {
public:
virtual ~Animal() = default;
};
// 定義兩個派生類,分別表示狗和貓
class Dog : public Animal {
public:
void bark() const {
std::cout << "Woof!"<< std::endl;
}
};
class Cat : public Animal {
public:
void meow() const {
std::cout << "Meow!"<< std::endl;
}
};
// 定義一個訪問者類,用于實現(xiàn)雙重分派
class Visitor {
public:
virtual void visit(const Dog& dog) = 0;
virtual void visit(const Cat& cat) = 0;
};
// 定義一個具體的訪問者類,實現(xiàn)對狗和貓的訪問操作
class AnimalVisitor : public Visitor {
public:
void visit(const Dog& dog) override {
dog.bark();
}
void visit(const Cat& cat) override {
cat.meow();
}
};
// 修改Animal類,添加accept方法,用于接受訪問者
class Animal {
public:
virtual ~Animal() = default;
virtual void accept(Visitor& visitor) const = 0;
};
// 更新Dog和Cat類,實現(xiàn)accept方法
class Dog : public Animal {
public:
void bark() const {
std::cout << "Woof!"<< std::endl;
}
void accept(Visitor& visitor) const override {
visitor.visit(*this);
}
};
class Cat : public Animal {
public:
void meow() const {
std::cout << "Meow!"<< std::endl;
}
void accept(Visitor& visitor) const override {
visitor.visit(*this);
}
};
int main() {
Dog dog;
Cat cat;
AnimalVisitor visitor;
dog.accept(visitor); // 輸出 "Woof!"
cat.accept(visitor); // 輸出 "Meow!"
return 0;
}
在這個例子中,我們首先定義了一個基類Animal
,以及兩個派生類Dog
和Cat
。然后,我們定義了一個訪問者類Visitor
,它包含兩個純虛函數(shù)visit
,分別用于訪問Dog
和Cat
。接下來,我們定義了一個具體的訪問者類AnimalVisitor
,它實現(xiàn)了Visitor
接口,并在visit
方法中調(diào)用了Dog
和Cat
的相應(yīng)方法。最后,我們修改了Animal
類,添加了一個accept
方法,用于接受訪問者。在Dog
和Cat
類中,我們實現(xiàn)了accept
方法,并在其中調(diào)用了訪問者的visit
方法。
這樣,我們就實現(xiàn)了一個自定義的visit
函數(shù),它可以根據(jù)傳入的參數(shù)類型自動選擇相應(yīng)的操作。在main
函數(shù)中,我們創(chuàng)建了一個AnimalVisitor
對象,并使用它訪問Dog
和Cat
對象,分別輸出"Woof!“和"Meow!”。