Честно говоря, мне не нравится виртуальная диспетчеризация, класс интерфейса. По этой причине я хочу реализовать собственные классы без базового абстрактного класса. Чтобы быть образным, я реализую MyCustomWidget, и некоторые его методы были реализованы, другие - нет, потому что это необязательно.реализовать виртуальный метод условный в C++ 11
// here is my custom widget class, which 'show' method is implemented, but 'close' method is not.
struct MyCustomWidget
{
void show(){ std::cout << "Hey" << std::endl; }
//void close(){ std::cout << "Bye" << std::endl; }
};
// here is your custom widget class, which 'show' is not implemented but 'close' is .
struct YourCustomWidget
{
//void show(){}
void close(){ std::cout << "Bye" << std::endl;}
};
// common widget class, which may stored within any custom widgets.
struct Widget
{
Widget() = default;
template< typename CustomWidget >
void add(CustomWidget cw)
{
auto child = std::make_unique< proxy<CustomWidget> >(std::move(cw))
childs.push_back(std::move(child));
}
void show()
{
for(auto & e : childs)
e->show();
}
void close()
{
for(auto& e : childs)
e->close();
}
private:
struct proxy_base
{
virtual void show() = 0;
virtual void close() = 0;
virtual ~proxy_base(){}
};
template< typename CustomWidget >
struct proxy : public proxy_base
{
explicit proxy(CustomWidget cw_) : cw(std::move(cw_))
{}
void show() override final
{ // -------------->>>>>> (1)
// call cw.show() if cw has 'show' method, otherwise nothing.
}
void close() override final
{ /// ---------------->>>> (2)
// call cw.close if cw has a 'close' method, otherwise nothing.
}
CustomWidget cw;
};
std::vector< std::unique_ptr<proxy_base> >childs;
};
int main()
{
Widget w;
w.add(MyCustomWidget());
w.add(YourCustomWidget());
w.show();
//.... a lot of code
w.close();
}
Мой вопрос прост: как мне осуществить, что (1) и (2) виртуальные методы?
Редактировать: Я вижу, что на этот вопрос уже был дан ответ. Позвольте мне изменить свой вопрос. Q2: (1) и (2) методы являются «окончательными», а в базовом классе они объявлены как чистые виртуальные, для этой ситуации компилятор может оптимизировать виртуальную таблицу и избежать ее? Я заинтересован в GCC, CLang и Visual Studio 2013.
возможно дубликат [Можно ли написать шаблон C++ для проверки существования некоторой функции в?] (Http://stackoverflow.com/questions/257288/is-it-possible-to-write -ac-template-to-check-for-a-functions-существования) – KeatsPeeks
Я думаю, что идиома SFINAE идеально подходит к вашей проблеме, см. ответ на вопрос, который я обозначил как дубликат – KeatsPeeks
ouh, greate !!! Благодарю. – Khurshid