Могу ли я научить Dynamic_cast<>() новым трюкам? ⇐ C++
-
Гость
Могу ли я научить Dynamic_cast<>() новым трюкам?
Есть ли в C++ способ создать ваш класс таким образом, чтобы, имея указатель на ваш класс, вы могли указать динамическому_cast(), как выполнить приведение к другому классу, для которого вы создаете оболочку реализации? Поможет ли актерский состав добиться цели? Представьте, что у меня есть базовый класс абстрактного интерфейса, и я извлекаю из него конкретный А, а также конкретный Б, но конкретный Б оборачивает интерфейс в объект типа конкретный А. Если я получу запрос на приведение к бетону A из бетона A, я бы хотел, чтобы он сработал:
класс Abstract { публика: виртуальный недействительный интерфейс () = 0; }; класс конкретA: public Abstract { публика: виртуальный недействительный интерфейс(); }; класс бетонB: public Abstract { публика: бетонB(бетонA и базовый элемент) : _underlying(&основание) { } виртуальный недействительный интерфейс(); оператор бетонA*() { вернуть _базовый; } частный: бетонA *_underlying; }; пустота мойТест() { бетонA myClassA; бетонB myClassB (myClassA); Аннотация *abstract = &myClassB; конкретA *underlying = Dynamic_cast(abstract); }
Есть ли в C++ способ создать ваш класс таким образом, чтобы, имея указатель на ваш класс, вы могли указать динамическому_cast(), как выполнить приведение к другому классу, для которого вы создаете оболочку реализации? Поможет ли актерский состав добиться цели? Представьте, что у меня есть базовый класс абстрактного интерфейса, и я извлекаю из него конкретный А, а также конкретный Б, но конкретный Б оборачивает интерфейс в объект типа конкретный А. Если я получу запрос на приведение к бетону A из бетона A, я бы хотел, чтобы он сработал:
класс Abstract { публика: виртуальный недействительный интерфейс () = 0; }; класс конкретA: public Abstract { публика: виртуальный недействительный интерфейс(); }; класс бетонB: public Abstract { публика: бетонB(бетонA и базовый элемент) : _underlying(&основание) { } виртуальный недействительный интерфейс(); оператор бетонA*() { вернуть _базовый; } частный: бетонA *_underlying; }; пустота мойТест() { бетонA myClassA; бетонB myClassB (myClassA); Аннотация *abstract = &myClassB; конкретA *underlying = Dynamic_cast(abstract); }
Мобильная версия