Unix / Linux - Verwenden von Shell-Variablen
In diesem Kapitel erfahren Sie, wie Sie Shell-Variablen in Unix verwenden. Eine Variable ist eine Zeichenfolge, der wir einen Wert zuweisen. Der zugewiesene Wert kann eine Nummer, ein Text, ein Dateiname, ein Gerät oder eine andere Art von Daten sein.
Eine Variable ist nichts anderes als ein Zeiger auf die tatsächlichen Daten. Mit der Shell können Sie Variablen erstellen, zuweisen und löschen.
Variablennamen
Der Name einer Variablen darf nur Buchstaben (a bis z oder A bis Z), Zahlen (0 bis 9) oder den Unterstrich (_) enthalten.
Konventionell haben Unix-Shell-Variablen ihre Namen in UPPERCASE.
Die folgenden Beispiele sind gültige Variablennamen -
_ALI
TOKEN_A
VAR_1
VAR_2
Es folgen Beispiele für ungültige Variablennamen -
2_VAR
-VARIABLE
VAR1-VAR2
VAR_A!
Der Grund, warum Sie keine anderen Zeichen verwenden können, wie z !, *, oder - ist, dass diese Zeichen eine besondere Bedeutung für die Shell haben.
Variablen definieren
Variablen sind wie folgt definiert:
variable_name=variable_value
Zum Beispiel -
NAME="Zara Ali"
Das obige Beispiel definiert die Variable NAME und weist ihr den Wert "Zara Ali" zu. Variablen dieses Typs werden aufgerufenscalar variables. Eine skalare Variable kann jeweils nur einen Wert enthalten.
Mit Shell können Sie jeden gewünschten Wert in einer Variablen speichern. Zum Beispiel -
VAR1="Zara Ali"
VAR2=100
Zugriff auf Werte
Um auf den in einer Variablen gespeicherten Wert zuzugreifen, müssen Sie dem Namen das Dollarzeichen voranstellen ($) -
Das folgende Skript greift beispielsweise auf den Wert der definierten Variablen NAME zu und druckt ihn auf STDOUT -.
#!/bin/sh
NAME="Zara Ali"
echo $NAME
Das obige Skript erzeugt den folgenden Wert:
Zara Ali
Schreibgeschützte Variablen
Shell bietet eine Möglichkeit, Variablen mithilfe des schreibgeschützten Befehls als schreibgeschützt zu markieren. Nachdem eine Variable als schreibgeschützt markiert wurde, kann ihr Wert nicht mehr geändert werden.
Das folgende Skript generiert beispielsweise einen Fehler beim Versuch, den Wert von NAME zu ändern.
#!/bin/sh
NAME="Zara Ali"
readonly NAME
NAME="Qadiri"
Das obige Skript generiert das folgende Ergebnis:
/bin/sh: NAME: This variable is read only.
Variablen deaktivieren
Durch Deaktivieren oder Löschen einer Variablen wird die Shell angewiesen, die Variable aus der Liste der verfolgten Variablen zu entfernen. Sobald Sie eine Variable deaktiviert haben, können Sie nicht mehr auf den in der Variablen gespeicherten Wert zugreifen.
Es folgt die Syntax zum Deaktivieren einer definierten Variablen mithilfe von unset Befehl -
unset variable_name
Der obige Befehl hebt den Wert einer definierten Variablen auf. Hier ist ein einfaches Beispiel, das zeigt, wie der Befehl funktioniert:
#!/bin/sh
NAME="Zara Ali"
unset NAME
echo $NAME
Das obige Beispiel druckt nichts. Sie können den Befehl unset nicht verwenden, umunset Variablen, die markiert sind readonly.
Variablentypen
Wenn eine Shell ausgeführt wird, sind drei Haupttypen von Variablen vorhanden:
Local Variables- Eine lokale Variable ist eine Variable, die in der aktuellen Instanz der Shell vorhanden ist. Es ist nicht für Programme verfügbar, die von der Shell gestartet werden. Sie werden an der Eingabeaufforderung festgelegt.
Environment Variables- Eine Umgebungsvariable steht jedem untergeordneten Prozess der Shell zur Verfügung. Einige Programme benötigen Umgebungsvariablen, um ordnungsgemäß zu funktionieren. Normalerweise definiert ein Shell-Skript nur die Umgebungsvariablen, die von den von ihm ausgeführten Programmen benötigt werden.
Shell Variables- Eine Shell-Variable ist eine spezielle Variable, die von der Shell festgelegt wird und von der Shell benötigt wird, um ordnungsgemäß zu funktionieren. Einige dieser Variablen sind Umgebungsvariablen, während andere lokale Variablen sind.