Implizite Konvertierungen in C
In den jüngsten Diskussionen über implizite Konvertierungen in C sind Fragen zur Anwendbarkeit mehrerer Konvertierungen in einem einzigen Vorgang aufgekommen . Um dieses Konzept zu verdeutlichen, untersuchen wir den folgenden Code:
<code class="cpp">#include <string> struct A { A( const std::string & s ) {} }; void func( const A & a ) { } int main() { func( "one" ); // error func( A("two") ); // ok func( std::string("three") ); // ok }</code>
Wie eingangs erwähnt, ist der erste Funktionsaufruf ein Fehler, da keine direkte Konvertierung von einem const char* in ein A erfolgt. Während eine Konvertierung von Wenn eine Zeichenfolge in A vorhanden ist, wären für ihre Verwendung zwei aufeinanderfolgende Konvertierungen erforderlich.
Gemäß dem C-Standard (SC22-N-4411.pdf), Abschnitt 12.3.4 mit dem Titel „Konvertierungen“:
" Höchstens eine benutzerdefinierte Konvertierung (Konstruktor oder Konvertierungsfunktion) wird implizit auf einen einzelnen Wert angewendet. :string &) und die implizite Konvertierung von const char* in std::string (das dann in ein A umgewandelt wird) zum Argument „one“.
Daher die ursprüngliche Behauptung, dass der erste Funktionsaufruf erfolgen würde Das Ergebnis ist korrekt. Der C-Standard gibt ausdrücklich an, dass nur eine implizite benutzerdefinierte Konvertierung zulässig ist, wodurch verhindert wird, dass der Compiler die erforderlichen Schritte ausführt, um den Parametertyp der Funktion zu erfüllen.
Das obige ist der detaillierte Inhalt vonKönnen in C mehrere implizite Konvertierungen in einem einzigen Vorgang angewendet werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!