Namespaces
Variants

C attribute: deprecated (since C23)

From cppreference.net

Gibt an, dass der mit diesem Attribut deklarierte Name oder die Entität veraltet ist, das heißt, die Verwendung ist erlaubt, aber aus bestimmten Gründen nicht empfohlen.

Inhaltsverzeichnis

Syntax

[[ deprecated ]]
[[ __deprecated__ ]]
(1)
[[ deprecated ( Zeichenkettenliteral ) ]]
[[ __deprecated__ ( Zeichenkettenliteral ) ]]
(2)
string-literal - Text, der zur Erläuterung der Hintergründe für die Veraltung und/oder zur Vorschlag eines Ersatzes verwendet werden könnte

Erklärung

Gibt an, dass die Verwendung des Namens oder der Entität, die mit diesem Attribut deklariert wurde, erlaubt ist, aber aus bestimmten Gründen nicht empfohlen wird. Compiler geben typischerweise Warnungen bei solchen Verwendungen aus. Der string-literal , falls angegeben, wird normalerweise in die Warnungen eingeschlossen.

Dieses Attribut ist in Deklarationen der folgenden Namen oder Entitäten zulässig:

  • struct / union : struct [ [ deprecated ] ] S ; ,
  • Typedef-Name : [ [ deprecated ] ] typedef S * PS ; ,
  • Objekte: [ [ deprecated ] ] int x ; ,
  • Struct/Union-Member: union U { [ [ deprecated ] ] int n ; } ; ,
  • Funktion : [ [ deprecated ] ] void f ( void ) ; ,
  • Enumeration : enum [ [ deprecated ] ] E { } ; ,
  • Enumerator: enum { A [ [ deprecated ] ] , B [ [ deprecated ] ] = 42 } ; .

Ein als nicht veraltet deklarierter Name kann erneut als veraltet deklariert werden. Ein als veraltet deklarierter Name kann nicht durch erneute Deklaration ohne dieses Attribut als nicht veraltet deklariert werden.

Beispiel

#include <stdio.h>
[[deprecated]]
void TriassicPeriod(void)
{
    puts("Triassic Period: [251.9 - 208.5] million years ago.");
}
[[deprecated("Use NeogenePeriod() instead.")]]
void JurassicPeriod(void)
{
    puts("Jurassic Period: [201.3 - 152.1] million years ago.");
}
[[deprecated("Use calcSomethingDifferently(int).")]]
int calcSomething(int x)
{
    return x * 2;
}
int main(void)
{
    TriassicPeriod();
    JurassicPeriod();
}

Mögliche Ausgabe:

Triassic Period: [251.9 - 208.5] million years ago.
Jurassic Period: [201.3 - 152.1] million years ago.
prog.c:23:5: warning: 'TriassicPeriod' is deprecated [-Wdeprecated-declarations]
    TriassicPeriod();
    ^
prog.c:3:3: note: 'TriassicPeriod' has been explicitly marked deprecated here
[[deprecated]]
  ^
prog.c:24:5: warning: 'JurassicPeriod' is deprecated: Use NeogenePeriod() instead. [-Wdeprecated-declarations]
    JurassicPeriod();
    ^
prog.c:9:3: note: 'JurassicPeriod' has been explicitly marked deprecated here
[[deprecated("Use NeogenePeriod() instead.")]]
  ^
2 warnings generated.

Siehe auch

C++ Dokumentation für deprecated