$GLOBALS

(PHP 4, PHP 5, PHP 7, PHP 8)

$GLOBALSReferenziert alle Variablen, die im globalen Gültigkeitsbereich vorhanden sind

Beschreibung

Ein assoziatives Array, das Referenzen auf alle Variablen enthält, die derzeit im globalen Gültigkeitsbereich (Scope) des Skripts bekannt sind. Die Namen der jeweiligen Variablen sind die Schlüsselwerte, um auf den Inhalt der jeweils referenzierten Variablen zuzugreifen.

Beispiele

Beispiel #1 $GLOBALS-Beispiel

<?php
function test() {
    
$foo "local variable";

    echo 
'$foo in global scope: ' $GLOBALS["foo"] . "\n";
    echo 
'$foo in current scope: ' $foo "\n";
}

$foo "Example content";
test();
?>

Das oben gezeigte Beispiel erzeugt eine ähnliche Ausgabe wie:

$foo in global scope: Example content
$foo in current scope: local variable

Warnung

Seit PHP 8.1.0 wird der Schreibzugriff auf das gesamte $GLOBALS-Array nicht mehr unterstützt:

Beispiel #2 Das Schreiben des gesamten $GLOBALS führt zu einem Fehler

<?php
 
// Erzeugt einen Kompilierungsfehler:
 
$GLOBALS = [];
 
$GLOBALS += [];
 
$GLOBALS =& $x;
 
$x =& $GLOBALS;
 unset(
$GLOBALS);
 
array_pop($GLOBALS);
 
// ...und jede andere Schreib-/Lese-Schreiboperation auf $GLOBALS
 
?>

Anmerkungen

Hinweis:

Dies ist eine 'Superglobale' oder automatisch globale Variable. Dies bedeutet, dass sie innerhalb des Skripts in jedem Geltungsbereich sichtbar ist. Es ist nicht nötig, sie mit global $variable bekannt zu machen, um aus Funktionen oder Methoden darauf zuzugreifen.

Hinweis: Verfügbarkeit der Variablen

Im Gegensatz zu allen anderen Superglobals ist $GLOBALS notwendigerweise immer in PHP verfügbar.

Hinweis:

Seit PHP 8.1.0 ist $GLOBALS eine schreibgeschützte Kopie der globalen Symboltabelle. Das heißt, globale Variablen können nicht über diese Kopie verändert werden. Zuvor war das Array $GLOBALS vom üblichen Verhalten der Wertübergabe (by-value) von PHP-Arrays ausgenommen und globale Variablen konnten über seine Kopie geändert werden.

<?php
// Vor PHP 8.1.0
$a 1;
$globals $GLOBALS// Eine by-value-Kopie
$globals['a'] = 2;
var_dump($a); // int(2)

// Seit PHP 8.1.0
// $a wird dadurch nicht mehr verändert. Das vorherige Verhalten verletzte die Semantik von by-value.
$globals $GLOBALS;
$globals['a'] = 1;

// Um das vorherige Verhalten wiederherzustellen, durchlaufen Sie die Kopie und übertragen jede Eigenschaft zurück auf $GLOBALS.
foreach ($globals as $key => $value) {
    
$GLOBALS[$key] = $value;
}
?>

Hier Kannst Du einen Kommentar verfassen


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

PHP cURL-Tutorial: Verwendung von cURL zum Durchführen von HTTP-Anfragen

cURL ist eine leistungsstarke PHP-Erweiterung, die es Ihnen ermöglicht, mit verschiedenen Servern über verschiedene Protokolle wie HTTP, HTTPS, FTP und mehr zu kommunizieren. ...

TheMax

Autor : TheMax
Kategorie: PHP-Tutorials

Midjourney Tutorial - Anleitung für Anfänger

Über Midjourney, dem Tool zur Erstellung digitaler Bilder mithilfe von künstlicher Intelligenz, gibt es ein informatives Video mit dem Titel "Midjourney Tutorial auf Deutsch - Anleitung für Anfänger" ...

Mike94

Autor : Mike94
Kategorie: KI Tutorials

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

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

Wer kennt sich mit Selenium aus oder hat zufällig ein geeignetes Script?

That's a complex task, and using Selenium with a cron job on your local machine to process a large number of URLs might not be the most efficient ...

Geschrieben von moleculegel am 07.01.2025 05:27:01
Forum: PHP Developer Forum
Einträge die älter als 24h sind in der PostgreSQL Datenbank löschen

Stelle mal deine Frage bei ChatGPT, da bekommst du bestimmt eine Lösung. UNGLAUBLICH! Das hat funktioniert. Eine Genaue Anforderung "UseCase" sc ...

Geschrieben von sharbich am 06.01.2025 23:33:29
Forum: SQL / Datenbanken
Einträge die älter als 24h sind in der PostgreSQL Datenbank löschen

Stelle mal deine Frage bei ChatGPT, da bekommst du bestimmt eine Lösung.

Geschrieben von scatello am 06.01.2025 21:55:00
Forum: SQL / Datenbanken
Einträge die älter als 24h sind in der PostgreSQL Datenbank löschen

Dann beschwert sich PostgreSQL, die Abfrage ist nicht richtig. Wie das mit PostgreSQL richtig geht, musst du in der Doku nachlesen, weiß ich dann ...

Geschrieben von sharbich am 06.01.2025 21:45:43
Forum: SQL / Datenbanken