Heim >Backend-Entwicklung >C++ >Ist das Binden einer Const-Referenz an ein temporäres Unterobjekt in C ein Fehler oder ein erwartetes Verhalten?

Ist das Binden einer Const-Referenz an ein temporäres Unterobjekt in C ein Fehler oder ein erwartetes Verhalten?

Linda Hamilton
Linda HamiltonOriginal
2024-10-26 11:26:29938Durchsuche

Is Binding a Const Reference to a Temporary Sub-Object in C   a Bug or Expected Behavior?

Binden einer Const-Referenz an ein temporäres Unterobjekt: Ein Rätsel

Der folgende C-Codeausschnitt zeigt eine Diskrepanz im Verhalten verschiedener Compiler beim Versuch, einen const-Verweis an ein Unterobjekt eines temporären Objekts zu binden:

<code class="cpp">#include <stdio.h>

struct P2d {
    double x, y;
    P2d(double x, double y) : x(x), y(y) {}
    ~P2d() { printf("Destructor called\n"); }
};

P2d center() {
    return P2d(10, 10);
}

int main(int argc, const char *argv[]) {
    const double& x = center().x;  // Bind a reference to temporary's x member
    printf("x = %.18g\n", x); // Expected: 10
    return 0;
}</code>

Bug oder erwartetes Verhalten?

Compiler wie g beenden die Lebensdauer des temporäre P2d-Instanz vor der Eingabe von printf in main, aber der Wert des Doppelelements x bleibt weiterhin erhalten. Dies wird erreicht, indem ein weiteres temporäres Double erstellt wird, um den Wert zu kopieren, anstatt an das Mitglied des ursprünglichen Temporärs zu binden.

Andererseits verlängert Clang korrekterweise die Lebensdauer des P2d-Temporärs, um sie an die der x-Referenz anzupassen, was Folgendes ermöglicht der Destruktor, der nach dem printf in main aufgerufen werden soll.

Diese Diskrepanz wirft die Frage auf: Ist das Verhalten von g ein Fehler oder gemäß dem C-Standard zulässig?

Analyse und Lösung

CWG 1651 bringt Licht in dieses Problem:


Das Binden einer Referenz an ein Unterobjekt sollte die Lebensdauer temporärer Objekte nicht verlängern.


Unter aktuellen Standards können andere Objekte als Skalare, wie z. B. Klassen oder Arrays, die Lebensdauer des temporären Objekts verlängern.

Compiler-Verhalten

  • GCC: Verlängert die Lebensdauer nur für Klassen- oder Array-Unterobjekte, basierend auf der CWG 1651-Auflösung.
  • Clang: Implementiert bereits die in N3918 beschriebenen Regeln zur Lebensdauerverlängerung. was die Lebensdauer aller temporären Unterobjekte verlängert.

Fazit

Basierend auf dem aktuellen Wortlaut des C-Standards ist das Verhalten von GCC technisch korrekt, während die Implementierung von Clang spiegelt die vorgeschlagenen Änderungen in DR 1651 wider. Es ist wahrscheinlich, dass der Standard überarbeitet wird, um diese Änderung in Zukunft widerzuspiegeln.

Das obige ist der detaillierte Inhalt vonIst das Binden einer Const-Referenz an ein temporäres Unterobjekt in C ein Fehler oder ein erwartetes Verhalten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn