C-Referenzvariablen zurückgeben: Das Gute, das Schlechte und das Hässliche
Die Frage, ob es „böse“ ist, ein C zurückzugeben Die Referenzvariable hat in der Programmiergemeinschaft eine Debatte ausgelöst. Das Verständnis der potenziellen Fallstricke und Best Practices kann Ihnen helfen, fundierte Entscheidungen zu treffen.
Was ist das Problem?
Einigen zufolge kann die Rückgabe einer Referenz das Risiko von Speicherlecks erhöhen wenn es sich auf ein Objekt bezieht, das nach dem Funktionsaufruf zerstört wird. Dies kann passieren, wenn:
Die bösen Beispiele
Diese Beispiele Veranschaulichen Sie die Gefahren:
int& getInt() { int i; return i; // DON'T DO THIS }
Dies gibt einen Verweis auf eine dem Stapel zugewiesene Variable zurück, die nach dem Funktionsaufruf zerstört wird, was zu undefiniertem Verhalten führt.
int& getInt() { int* i = new int; return *i; // DON'T DO THIS }
Dies gibt einen Verweis auf zurück eine Heap-zugewiesene Variable, aber der Client muss sie manuell mit der verwirrenden Syntax delete &reference löschen.
Das Beste Üben Sie
Um diese Probleme zu vermeiden, befolgen Sie diese Richtlinien:
Fazit
Die Rückgabe von Referenzen kann zwar praktisch sein, ist es aber Es ist wichtig, sich der potenziellen Risiken bewusst zu sein. Indem Sie die oben beschriebenen Best Practices befolgen, können Sie Speicherlecks vermeiden und Code schreiben, der sicher und wartbar ist.
Das obige ist der detaillierte Inhalt vonWann ist die Rückgabe einer C-Referenzvariablen sicher (und wann nicht)?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!