Heim  >  Artikel  >  Backend-Entwicklung  >  C++-Kompilierungsfehler: Statische Mitglieder können nicht durch konstante Ausdrücke initialisiert werden. Wie kann das Problem gelöst werden?

C++-Kompilierungsfehler: Statische Mitglieder können nicht durch konstante Ausdrücke initialisiert werden. Wie kann das Problem gelöst werden?

王林
王林Original
2023-08-22 08:13:101486Durchsuche

In der C++-Programmierung sind statische Mitglieder öffentliche Eigenschaften einer Klasse. Auf sie kann zugegriffen werden, ohne auf ein bestimmtes Objekt angewiesen zu sein, da ihr Lebenszyklus mit dem der Klasse identisch ist und nur eine Kopie vorhanden ist. Bei der Verwendung statischer Elemente tritt jedoch manchmal ein Kompilierungsfehler auf, der besagt, dass statische Elemente nicht durch konstante Ausdrücke initialisiert werden können. Wie tritt dieser Fehler auf und wie kann er behoben werden? In diesem Artikel wird es unter zwei Gesichtspunkten vorgestellt.

1. Gründe, warum statische Elemente nicht durch konstante Ausdrücke initialisiert werden können

Im C++11-Standard wird das Konzept des konstanten Ausdrucks constexpr eingeführt, der sich auf einen Ausdruck bezieht, dessen Ergebnis zur Kompilierungszeit berechnet werden kann. Konstanten können mit constexpr definiert werden, zum Beispiel:

constexpr int max(int a, int b) {
    return a > b ? a : b;
}

Bei Verwendung dieser Funktion kann der Compiler das Ergebnis zur Kompilierungszeit berechnen, sodass max(1, 2) als konstanter Ausdruck betrachtet werden kann. Sein Ergebnis ist 2. Wenn Sie jedoch bei Verwendung statischer Elemente versuchen, einen konstanten Ausdruck zum Initialisieren statischer Elementvariablen zu verwenden, tritt ein Kompilierungsfehler auf. Zum Beispiel:

class MyClass {
public:
    static constexpr int m_value = 10; // 编译错误
};

Dies liegt daran, dass die Initialisierungsreihenfolge statischer Elemente mit der Auswertungsreihenfolge konstanter Ausdrücke zusammenhängt. In C++ werden statische Elemente in der Reihenfolge der Deklaration initialisiert, und konstante Ausdrücke werden zur Kompilierungszeit ausgewertet. Wenn also ein statisches Element von einem konstanten Ausdruck abhängt, muss garantiert werden, dass es nach dem konstanten Ausdruck initialisiert wird.

2. Methoden zur Lösung des Problems, dass statische Elemente nicht durch konstante Ausdrücke initialisiert werden können.

Es gibt drei Methoden, um dieses Problem zu lösen:

1. Verwenden Sie ganzzahlige konstante Ausdrücke, um statische Elemente zu initialisieren.

Ein ganzzahliger konstanter Ausdruck ist a Ein spezieller konstanter Ausdruck, der nur ganzzahlige Literale, arithmetische Operatoren und Funktionen oder Mitglieder ohne Nebenwirkungen umfasst. Für statische Mitgliedsvariablen können Sie zum Initialisieren ganzzahlige konstante Ausdrücke verwenden, zum Beispiel:

class MyClass {
public:
    static const int m_value = 10; // 正确
};

Für andere Arten von statischen Mitgliedsvariablen können Sie diese Methode ebenfalls verwenden. Stellen Sie jedoch sicher, dass Sie für die Initialisierung ganzzahlige konstante Ausdrücke verwenden.

2. Inline-Variablen verwenden

Im C++17-Standard wird das Konzept der Inline-Variablen eingeführt, das die Definition von Variablen in Header-Dateien ermöglicht, ohne dass es zu mehreren Definitionsproblemen kommt. Für statische Mitgliedsvariablen können Sie beispielsweise Inline-Variablen zum Initialisieren verwenden:

class MyClass {
public:
    inline static int m_value = 10; // 正确
};

Durch die Verwendung von Inline-Variablen kann das Problem vermieden werden, dass statische Mitglieder nicht durch konstante Ausdrücke initialisiert werden können. Außerdem ist es praktischer und erfordert keine separate Definition von Variablen die Quelldatei.

3. Verzögerte Initialisierung verwenden

Verzögerte Initialisierung bedeutet Initialisierung, wenn statische Mitgliedsvariablen verwendet werden müssen. Diese Methode kann das Problem vermeiden, dass statische Mitglieder nicht durch konstante Ausdrücke initialisiert werden können, zum Beispiel:

class MyClass {
public:
    static int& m_value() {
        static int s_value = 10;
        return s_value;
    }
};

durch eine statische Mitgliedsfunktion Wenn Sie eine Referenz erstellen und diese dann initialisieren, wenn Sie statische Mitgliedsvariablen verwenden müssen, kann das Problem vermieden werden, dass statische Mitglieder nicht durch konstante Ausdrücke initialisiert werden können. Der Vorteil dieses Ansatzes besteht darin, dass Sie den Initialisierungszeitpunkt statischer Mitgliedsvariablen je nach Bedarf flexibel steuern und gleichzeitig unnötige Initialisierungen beim Programmstart vermeiden können.

Zusammenfassung

Statische Mitglieder sind öffentliche Eigenschaften einer Klasse, auf die zugegriffen werden kann, ohne auf ein bestimmtes Objekt angewiesen zu sein. Bei der Verwendung statischer Mitglieder tritt jedoch manchmal ein Kompilierungsfehler auf, der besagt, dass statische Mitglieder nicht durch konstante Ausdrücke initialisiert werden können. Der Grund für dieses Problem liegt darin, dass die Initialisierungsreihenfolge statischer Elemente mit der Auswertungsreihenfolge konstanter Ausdrücke zusammenhängt. Um dieses Problem zu lösen, können Sie ganzzahlige konstante Ausdrücke verwenden, um statische Elemente zu initialisieren, Inline-Variablen verwenden, um statische Elemente zu initialisieren, oder eine verzögerte Initialisierung verwenden, um das Problem zu vermeiden, dass statische Elemente nicht durch konstante Ausdrücke initialisiert werden können. Welche Methode zu wählen ist, hängt von der konkreten Situation ab und muss flexibel auf der Grundlage der tatsächlichen Bedürfnisse gewählt werden.

Das obige ist der detaillierte Inhalt vonC++-Kompilierungsfehler: Statische Mitglieder können nicht durch konstante Ausdrücke initialisiert werden. Wie kann das Problem gelöst werden?. 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