Im Bereich der Datenstrukturen ist es oft wichtig, Eigenschaften wie feste vs. variable Größe, heterogene vs. homogene Daten zu berücksichtigen, sortierte vs. unsortierte Daten und sequentieller vs. wahlfreier Zugriff. Obwohl es verschiedene STL-Container gibt, um bestimmte Kombinationen dieser Eigenschaften zu berücksichtigen, bleibt eine auffällige Lücke bestehen: das Fehlen eines Containers, der gleichzeitig variable Größe und Heterogenität unterstützt.
In C enthalten Container normalerweise Objekte eines einzigen Typs, danke auf die Macht der Vorlagen. In Fällen, in denen verschiedene Typen eine gemeinsame Basisklasse haben, kann man einen Container mit Zeigern auf die Basisklasse verwenden. Doch welche Optionen stehen bei der Verwaltung völlig unabhängiger Typen zur Verfügung?
Um dieser Herausforderung zu begegnen, bietet Boost zwei vielseitige Bibliotheken: boost::any und boost::variant.
Mit boost::any kann man problemlos einen heterogenen Container erstellen, der variable size:
<code class="cpp">std::list<boost::any> values; append_int(values, 42); append_string(values, "Hello");</code>
<code class="cpp">std::vector<boost::variant<unsigned, std::string>> vec; vec.push_back(44); vec.push_back("str"); vec.push_back(SomeOtherType(55, 65)); // Compilation error</code>
Das obige ist der detaillierte Inhalt vonWie kann C mit heterogenen Daten in Containern variabler Größe umgehen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!