Есть ли в C++ причина скрывать реализацию класса в исходном файле и позволять видеть только абстрактный класс в заголово ⇐ C++
Есть ли в C++ причина скрывать реализацию класса в исходном файле и позволять видеть только абстрактный класс в заголово
Я столкнулся со следующей проблемой.
Код структурирован следующим образом
Заголовочный файл пример.h
класс Abstract { публика: виртуальный ~Abstract() = по умолчанию; виртуальная пустота doSomething() = 0; }; std::shared_ptr getConcrete(); И в исходном файле пример.cpp
#include "example.h" класс Бетон: публичный Аннотация { публика: переопределение виртуальной пустоты doSomething() { //делаем что-то } }; std::shared_ptr getConcrete() { вернуть std::make_shared() } Это усложняет создание модульных тестов, особенно для частных членов/функций. Мой вопрос: есть ли в этом какой-то смысл??
Я бы сделал следующее
Заголовочный файл пример.h
класс Abstract { публика: виртуальный ~Abstract() = по умолчанию; виртуальная пустота doSomething() = 0; }; класс Бетон: публичный Аннотация { публика: переопределение виртуальной пустоты doSomething(); }; И в исходном файле пример.cpp
#include "example.h" void Бетон::doSomething() { //делаем что-то } Есть ли случаи, когда вторая реализация не соответствует первой?
Я столкнулся со следующей проблемой.
Код структурирован следующим образом
Заголовочный файл пример.h
класс Abstract { публика: виртуальный ~Abstract() = по умолчанию; виртуальная пустота doSomething() = 0; }; std::shared_ptr getConcrete(); И в исходном файле пример.cpp
#include "example.h" класс Бетон: публичный Аннотация { публика: переопределение виртуальной пустоты doSomething() { //делаем что-то } }; std::shared_ptr getConcrete() { вернуть std::make_shared() } Это усложняет создание модульных тестов, особенно для частных членов/функций. Мой вопрос: есть ли в этом какой-то смысл??
Я бы сделал следующее
Заголовочный файл пример.h
класс Abstract { публика: виртуальный ~Abstract() = по умолчанию; виртуальная пустота doSomething() = 0; }; класс Бетон: публичный Аннотация { публика: переопределение виртуальной пустоты doSomething(); }; И в исходном файле пример.cpp
#include "example.h" void Бетон::doSomething() { //делаем что-то } Есть ли случаи, когда вторая реализация не соответствует первой?
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Аниматор не позволит мне не позволять мне, а не код, чтобы отключить коллайдер. Почему?
Anonymous » » в форуме C# - 0 Ответы
- 11 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Как преобразовать полученный класс в базовый абстрактный общий класс при возврате из функции?
Anonymous » » в форуме C# - 0 Ответы
- 2 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Абстрактный класс PHPDOC не вставляет тип расширенного класса
в возвращаемые методы.
Anonymous » » в форуме Php - 0 Ответы
- 85 Просмотры
-
Последнее сообщение Anonymous
-