Namensräume
Varianten
Aktionen

Konvertierungskonstruktor

Von cppreference.com
< cpp‎ | Sprache
 
 
C++ Sprache
Allgemeine Themen
Kontrollfluss
Bedingte Ausführungsaussagen
if
Iterationsanweisungen (Schleifen)
for
Bereichs-for (C++11)
Sprunganweisungen
Funktionen
Funktionsdeklaration
Lambda-Funktionsausdruck
inline-Spezifizierer
Dynamische Ausnahmespezifikationen (bis C++17*)
noexcept-Spezifizierer (C++11)
Ausnahmen
Namensräume
Typen
Spezifizierer
const/volatile
decltype (C++11)
auto (C++11)
constexpr (C++11)
consteval (C++20)
constinit (C++20)
Speicherdauer-Spezifizierer
Initialisierung
Ausdrücke
Alternative Darstellungen
Literale
Boolesch - Ganzzahl - Gleitkommazahl
Zeichen - String - nullptr (C++11)
Benutzerdefinierte (C++11)
Dienstprogramme
Attribute (C++11)
Typen
typedef-Deklaration
Typalias-Deklaration (C++11)
Umwandlungen
Speicherzuweisung
Klassen
Klassenspezifische Funktionseigenschaften
explicit (C++11)
static

Spezielle Member-Funktionen
Templates
Sonstiges
 
 

Ein Konstruktor, der nicht mit dem Spezifizierer explicit deklariert ist und der mit einem einzelnen Parameter aufgerufen werden kann(bis C++11), wird als Konstruktor für implizite Typumwandlung bezeichnet.

Im Gegensatz zu expliziten Konstruktoren, die nur während der direkten Initialisierung (zu der auch explizite Umwandlungen wie static_cast gehören) berücksichtigt werden, werden Konstruktoren für implizite Typumwandlung auch während der Kopierinitialisierung als Teil einer benutzerdefinierten Umwandlungssequenz berücksichtigt.

Man sagt, dass ein Konstruktor für implizite Typumwandlung eine implizite Umwandlung von den Typen seiner Argumente (falls vorhanden) in den Typ seiner Klasse angibt. Beachten Sie, dass nicht-explizite benutzerdefinierte Umwandlungsfunktionen ebenfalls eine implizite Umwandlung angeben.

Implizit deklarierte und benutzerdefinierte nicht-explizite Kopierkonstruktoren und Verschiebekonstruktoren sind Konstruktoren für implizite Typumwandlung.

[bearbeiten] Beispiel

struct A
{
    A() { }         // converting constructor (since C++11)  
    A(int) { }      // converting constructor
    A(int, int) { } // converting constructor (since C++11)
};
 
struct B
{
    explicit B() { }
    explicit B(int) { }
    explicit B(int, int) { }
};
 
int main()
{
    A a1 = 1;      // OK: copy-initialization selects A::A(int)
    A a2(2);       // OK: direct-initialization selects A::A(int)
    A a3{4, 5};    // OK: direct-list-initialization selects A::A(int, int)
    A a4 = {4, 5}; // OK: copy-list-initialization selects A::A(int, int)
    A a5 = (A)1;   // OK: explicit cast performs static_cast, direct-initialization
 
//  B b1 = 1;      // error: copy-initialization does not consider B::B(int)
    B b2(2);       // OK: direct-initialization selects B::B(int)
    B b3{4, 5};    // OK: direct-list-initialization selects B::B(int, int)
//  B b4 = {4, 5}; // error: copy-list-initialization selected an explicit constructor
                   //        B::B(int, int)
    B b5 = (B)1;   // OK: explicit cast performs static_cast, direct-initialization
    B b6;          // OK, default-initialization
    B b7{};        // OK, direct-list-initialization
//  B b8 = {};     // error: copy-list-initialization selected an explicit constructor
                   //        B::B()
 
    [](...){}(a1, a4, a4, a5, b5); // may suppress "unused variable" warnings
}

[bearbeiten] Siehe auch