Heim >Backend-Entwicklung >C++ >Warum gibt „std::vector::reference' keine „bool'-Referenz zurück?
Warum gibt „vector
Betrachten Sie das folgende Beispiel:
#include <vector> struct A { void foo() {} }; template<typename T> void callIfToggled(bool v1, bool &v2, T &t) { if (v1 != v2) { v2 = v1; t.foo(); } } int main() { std::vector<bool> v = {false, true, false}; const bool f = false; A a; callIfToggled(f, v[0], a); callIfToggled(f, v[1], a); callIfToggled(f, v[2], a); }
Dieser Code kann mit Folgendem nicht kompiliert werden Fehler:
dk2.cpp:29:28: error: no matching function for call to 'callIfToggled(const bool&, std::vector<bool>::reference, A&)'
Das Problem tritt auf, weil 'std::vector
Vektorspezialisierung für 'bool'
Im Fall von 'std::vector
'fixed_vector' und 'Boost Containers'
Um dieses Problem zu mildern, können Sie Folgendes verwenden Strategie:
Beispiel für die Verwendung von „fixed_vector“:
template<typename t, typename... p> using fixed_vector = std::vector<typename foo<t>::type, p...>; int main() { fixed_vector<bool> v = {false, true, false}; const bool f = false; A a; callIfToggled(f, v[0], a); callIfToggled(f, v[1], a); callIfToggled(f, v[2], a); }
Beispiel für die Verwendung von „Boost Containers“:
#include <boost/container/vector.hpp> int main() { boost::container::vector<bool> v = {false, true, false}; const bool f = false; A a; callIfToggled(f, v[0], a); callIfToggled(f, v[1], a); callIfToggled(f, v[2], a); }
Das obige ist der detaillierte Inhalt vonWarum gibt „std::vector::reference' keine „bool'-Referenz zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!