Entschlüsselung des injizierten Klassennamens: Sein Zweck und seine Entwicklung in C
Einführung:
Das Konzept von Ein in C eingefügter Klassenname hat viele Programmierer verwirrt. Diese Funktion ermöglicht es einer Klasse, Mitglied ihrer selbst zu werden, was eine eindeutige Namensauflösung innerhalb des Klassenkörpers ermöglicht.
Zweck des eingefügten Klassennamens:
Der eingefügte Klassenname stellt dies sicher Im Bereich einer Klasse bezieht sich ihr eigener Name immer auf die aktuelle Klasse und nicht auf eine andere Klasse mit demselben Namen, die im selben umschließenden Bereich deklariert ist. Diese Unterscheidung ist in Szenarien wie Klassenmethoden von entscheidender Bedeutung, die entweder auf die Methode oder ein temporäres Objekt mit demselben Namen verweisen können.
Klarstellung in C 03:
Während die Idee einer Obwohl der injizierte Klassenname in C 98 existierte, wurde seine Terminologie in C 03 mit der Veröffentlichung des Abschnitts [class]/2 im C-Standard eingeführt. In diesem Abschnitt wird ausdrücklich darauf hingewiesen, dass ein Klassenname sowohl in den Bereich seiner Deklaration als auch in den Bereich der Klasse selbst eingefügt wird.
Vorteile innerhalb von Klassenvorlagen:
Der eingefügte Klassenname ist besonders nützlich in Klassenvorlagen. Dadurch kann die Vorlagenparameterliste weggelassen werden, wenn auf die aktuelle Instanziierung der Klasse verwiesen wird, was die Verwendung einfacher macht.
Historischer Hintergrund:
Schon vor C 98 war der ARM (Annotated Reference Manual) enthielt Bestimmungen, die die Verwendung eines Klassennamens in seiner eigenen Mitgliederliste ermöglichten. Dieses Konzept legte den Grundstein für die Formalisierung des injizierten Klassennamens in nachfolgenden C-Versionen.
Das obige ist der detaillierte Inhalt vonWas ist der Zweck und die Entwicklung des injizierten Klassennamens in C?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!