Portál AbcLinuxu, 4. května 2025 22:57
class TEST{ public: TEST(); typedef struct { int a; }ITEM; const ITEM items[]; };Nyní bych chtěl v konstruktoru třídy TEST() naplnit pole items. Plánuji potom zdědit tuto třídu (TEST) a každý potomek si vytvoří svoje pole items. Jak na to? Použití std::vector nebo array atd není možné (embeddded). Jediná pro mě zatím funkční varianta je mít takovýto konstruktor:
TEST(){ ITEM asfafafsfff[]={ {4},{5} }; itms=asfafafsfff; }Ale vůbec se mi to nelíbí. Navíc items nemůže být const a busí být definován jako ITEM * items.
To je jakýsi podivný mix C++ (class
), C (typedef struct
) a kdoví, možná i Javy (items[]
), ale nejspíš to má být „nekonečné“ pole na konci C99 struktury, které ovšem není ani vzdáleně kompatibilní s C++ (bez přetěžování new
a delete
), protože samo od sebe není jasné, jak tam mají fungovat konstruktory a destruktory…
Použití std::vector nebo array atd není možné (embeddded).
V jakém slova smyslu to není možné? To ten embedded systém nemá alokátor paměti? std::array
bude fungovat bez dynamické alokace, přesně k takovému použití je určené…
Kdo / co určuje velikost pole items
? Je k tomu přetížený operátor new
a delete
? Jak vypadá?
Ten každý potomek má být ve skutečnosti každá podtřída nebo každá instance? Nebylo by v prvním případě lepší mít to pole statické? (Ať tak nebo tak, asi by mělo být protected
a/nebo const
.)
#include <array> #include <cstdint> #include <utility> namespace { template <std::size_t Size> struct Test1 { struct Item { int a; }; template <typename... ALike> Test1(ALike&&... as) : items_{{.a = std::forward<ALike>(as)}...} { static_assert(sizeof...(as) <= Size); } protected: const Item items_[Size]; }; template <std::size_t Size> struct Test2 { struct Item { int a; }; template <typename... ALike> Test2(ALike&&... as) : items_{Item{.a = std::forward<ALike>(as)}...} { static_assert(sizeof...(as) <= Size); } protected: const std::array<Item, Size> items_; }; } // namespace int main() { Test1<6> t{1, 2, 3, 4, 5}; Test2<5>{1, 2, 3, 4}; }
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.