przygotowanie tego kodu z g ++ 4.7.0 (-Wall -Wextra -Werror -Wconversion -std=c++11
):Uniform inicjalizacji z {} raportowania niewykorzystaną zmienną
#include <iostream> // std::cout, std::endl
#include <string> // std::string
#include <utility> // std::move
void out(std::string const &message)
{
static int count{0};
std::cout << count++ << " = " << message << std::endl;
}
struct Foo
{
Foo() {out("constructor");}
~Foo() {out("destructor");}
Foo(Foo const &) {out("copy constructor");}
Foo & operator=(Foo const &) {out("copy via assignment"); return *this;}
Foo(Foo &&) {out("move constructor");}
Foo & operator=(Foo &&) {out("move via assignment"); return *this;}
};
int main()
{
auto bar{std::move(Foo())};
out("exiting main");
}
... wyniki w następujący błąd:
error: unused variable 'bar' [-Werror=unused-variable]
można usunąć błąd przez zmianę inicjalizacji bar
na jedną z poniższych:
/* 0 */ auto bar(std::move(Foo()));
/* 1 */ Foo bar{std::move(Foo())};
/* 2 */ Foo bar(std::move(Foo()));
/* 3 */ auto bar = std::move(Foo());
/* 4 */ Foo bar = std::move(Foo());
/* 5 */ auto bar __attribute__((unused)) {std::move(Foo())};
Po inicjalizacji bar
została zmieniona, wyjście jest zawsze:
0 = constructor
1 = move constructor
2 = destructor
3 = exiting main
4 = destructor
Dlaczego oryginalny bar
raport inicjalizacja nieużywaną zmienną?
Co dzieje się w środowisku wykonawczym, jeśli używasz "złej" wersji kodu i kompilujesz bez '-Werror'? –
@JohnZwinck ** błąd ** zmienia się w ** ostrzeżenie ** –
Wydaje się, że jest to po prostu nieobsłużony przypadek w nieużywanej logice ostrzegawczej zmiennej. Zgłoś błąd za pomocą gcc. – bames53