Syntax

Konstanten können mit dem Schlüsselwort const oder mit der Funktion defined() definiert werden. Während define() es ermöglicht, eine Konstante auf einen beliebigen Wert zu definieren, hat das Schlüsselwort const Einschränkungen, die im nächsten Absatz beschrieben werden. Einmal definiert, kann eine Konstante weder verändert noch gelöscht werden.

Wenn das Schlüsselwort const verwendet wird, werden nur skalare Ausdrücke (bool, int, float und string) und konstante Arrays, die nur skalare Ausdrücke enthalten, akzeptiert. Es ist möglich, Konstanten vom Typ resource zu definieren, dies sollte allerdings vermieden werden, da es zu unerwarteten Ergebnissen führen kann.

Auf den Wert einer Konstanten wird einfach durch die Angabe ihres Namens zugegriffen. Im Gegensatz zu Variablen wird einer Konstanten kein $ vorangestellt. Ebenso kann die Funktion constant() verwendet werden, um den Wert einer Konstanten auszulesen, wenn der Name der Konstanten dynamisch ermittelt wird. Mit der Funktion get_defined_constants() erhält man eine Liste aller definierten Konstanten.

Hinweis: Konstanten und (globale) Variablen befinden sich in unterschiedlichen Namensräumen. Das hat zum Beispiel zur Folge, dass true und $TRUE etwas völlig Verschiedenes sind.

Falls eine undefinierte Konstante verwendet wird, wird ein Error ausgelöst. Vor PHP 8.0.0 wurden undefinierte Konstanten als einfaches String-Wort (d. h. CONSTANT vs "CONSTANT") interpretiert. Dieses Rückfallverhalten ist von PHP 7.2.0 an missbilligt, und ein Fehler der Stufe E_WARNING wird ausgelöst, wenn es dazu kommt. Vor PHP 7.2.0 wurde stattdessen ein Fehler der Stufe E_NOTICEE_NOTICE ausgelöst. Siehe auch den Abschnitt im Handbuch, der erklärt, warum $foo[bar] falsch ist (es sei denn, bar ist eine Konstante). Dies gilt nicht für (vollständig) qualifizierte Konstanten, die immer einen Error auslösen, wenn sie undefiniert sind.

Hinweis: Um zu prüfen, ob eine Konstante gesetzt ist, kann die Funktion defined() verwendet werden.

Dies sind die Unterschiede zwischen Konstanten und Variablen:

  • Konstanten haben kein Dollarzeichen ($) vorangestellt;
  • Konstanten können überall definiert werden und auf Ihren Wert kann ohne Rücksicht auf die Regeln des Geltungsbereichs von Variablen zugegriffen werden;
  • Sobald Konstanten definiert sind, können sie nicht neu definiert oder gelöscht werden; und
  • Konstanten können nur als skalare Werte oder Arrays ausgewertet werden.

Beispiel #1 Definition von Konstanten

<?php
define
("KONSTANTE""Hallo Welt.");
echo 
KONSTANTE;     // Ausgabe: "Hallo Welt."
echo Konstante;     // Gibt einen Fehler aus: Undefined Constant "Konstante"
                    // Vor PHP 8.0.0 wird "Konstante" ausgegeben und eine
                    // Warnung angezeigt.
?>

Beispiel #2 Definition von Konstanten unter Verwendung des Schlüsselworts const

<?php
// Einfacher skalarer Wert
const KONSTANTE 'Hallo Welt';

echo 
KONSTANTE;

// Skalarer Ausdruck
const ANDERE_KONSTANTE KONSTANTE '; Ade Welt';
echo 
ANDERE_KONSTANTE;

const 
ANIMALS = array('Hund''Katze''Maus');
echo 
ANIMALS[1]; // gibt "Katze" aus

// Array-Konstante
define('ANIMALS', array(
    
'Hund',
    
'Katze',
    
'Maus'
));
echo 
ANIMALS[1]; // gibt "Katze" aus
?>

Hinweis:

Im Gegensatz zu Konstanten, welche mit define() erstellt werden, müssen über const definierte Konstanten auf der höchsten Ebene erstellt werden, weil sie bei der Kompilierung definiert werden. Das heißt, dass sie nicht innerhalb von Funktionen, Schleifen, if-Anweisungen oder try/catch-Blöcken definiert werden können.

Siehe auch

Hier Kannst Du einen Kommentar verfassen


Bitte gib mindestens 10 Zeichen ein.
Wird geladen... Bitte warte.
* Pflichtangabe
Es sind noch keine Kommentare vorhanden.

Grundlagen von Views in MySQL

Views in einer MySQL-Datenbank bieten die Möglichkeit, eine virtuelle Tabelle basierend auf dem Ergebnis einer SQL-Abfrage zu erstellen. ...

admin

Autor : admin
Kategorie: mySQL-Tutorials

Definition von Stored Procedures - eine Einführung

Stored Procedures sind vordefinierte SQL-Codeblöcke, die in einer Datenbank gespeichert sind und bei Bedarf aufgerufen werden können. ...

Bernie

Autor : ebiz-consult GmbH & Co. KG
Kategorie: mySQL-Tutorials

Wie kann man komplexe Abfragen mit SQL-Querys In MySQLi effektiv durchführen?

In diesem MySQL-Tutorial wird erklärt, wie komplexe SQL-Abfragen in MySQLi effizient durchgeführt werden können. Wir werden uns mit verschiedenen Aspekten der Datenbankabfrage beschäftigen und spezifische Methoden kennenlernen. ...

TheMax

Autor : TheMax
Kategorie: mySQL-Tutorials

Tutorial veröffentlichen

Tutorial veröffentlichen

Teile Dein Wissen mit anderen Entwicklern weltweit

Du bist Profi in deinem Bereich und möchtest dein Wissen teilen, dann melde dich jetzt an und teile es mit unserer PHP-Community

mehr erfahren

Tutorial veröffentlichen

Professioneller Webentwickler & Webdesigner

Of course, here is the translation: Hello, Thank you for your interest in the long-term project. Your extensive skills and experience in web dev ...

Geschrieben von Athelstan am 15.04.2024 09:25:39
Forum: Jobgesuche
Wir stellen unsere SEO-Agentur vor

Hallo In der heutigen digitalen Welt war es für Unternehmen noch nie so einfach, ihre Reichweite weltweit zu vergrößern. Wenn Sie außerhalb I ...

Geschrieben von thomasmuller am 14.04.2024 07:18:33
Forum: User stellen sich vor
Spielplan für 4 Gruppen zu je 6 Teams auf 2 Feldern

Hallöchen zusammen, ich versuche derzeit unseren Excel-Spielplan in PHP zu überführen. Eigentlich bin ich auch shon fertig - wenn da nicht dies ...

Geschrieben von derH0st am 11.04.2024 15:58:37
Forum: PHP Developer Forum
PHP 8.3.3 - App kann auf dem PC nicht ausgeführt werden

Problem gelöst. Die php.exe hatte einen defekt. Neue heruntergeladen und fertig.

Geschrieben von Tetra1081 am 10.04.2024 16:49:14
Forum: PHP Developer Forum