Hash: Unterschied zwischen den Versionen

Aus Foxwiki
K Textersetzung - „Bash/Builtins“ durch „Bash/Builtin“
 
(27 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 3: Zeile 3:


== Beschreibung ==
== Beschreibung ==
== Installation ==
; Programmpfade merken oder anzeigen
== Anwendungen ==
* Ermittelt und speichert den vollständigen Pfadnamen jedes Kommandos NAME
=== Fehlerbehebung ===
* Wenn keine Argumente angegeben werden, werden Informationen über gespeicherte Kommandos angezeigt
== Syntax ==
=== Optionen ===
{| class="wikitable sortable options"
|-
! Option !! Beschreibung
|-
| -d || Vergessen des Speicherortes für jeden NAME
|-
| -l || Anzeige in einem Format, das als Eingabe wiederverwendet werden kann
|-
| -p || Pfadname verwendet PATHNAME als den vollständigen Pfadnamen von NAME
|-
| -r || vergisst alle gespeicherten Pfade
|-
| -t || gibt den Speicherort jedes NAMENS aus, wobei jedem Speicherort der entsprechende NAME vorangestellt wird, wenn mehrere NAMEs angegeben sind
|}
 
=== Parameter ===
=== Umgebungsvariablen ===
=== Exit-Status ===
== Konfiguration ==
=== Dateien ===
== Sicherheit ==
== Dokumentation ==
=== RFC ===
=== Man-Pages ===
=== Info-Pages ===
== Siehe auch ==
== Links ==
=== Projekt-Homepage ===
=== Weblinks ===
=== Einzelnachweise ===
<references />
== Testfragen ==
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 1''
<div class="mw-collapsible-content">'''Antwort1'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 2''
<div class="mw-collapsible-content">'''Antwort2'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 3''
<div class="mw-collapsible-content">'''Antwort3'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 4''
<div class="mw-collapsible-content">'''Antwort4'''</div>
</div>
<div class="toccolours mw-collapsible mw-collapsed">
''Testfrage 5''
<div class="mw-collapsible-content">'''Antwort5'''</div>
</div>


[[Kategorie:Entwurf]]
= TMP =
== Beschreibung  ==
; Ein angegebenes Kommando muss von der Shell gesucht werden
; Ein angegebenes Kommando muss von der Shell gesucht werden
* Die Suche, vor allem wenn sie die Angaben aus PATH einschließt, kostet Zeit.  
* Die Suche, vor allem wenn sie die Angaben aus PATH einschließt, kostet Zeit.  
Zeile 74: Zeile 16:
* Beim nächsten Zugriff auf das Kommando wird haman den Geschwindigkeitszuwachs spüren.
* Beim nächsten Zugriff auf das Kommando wird haman den Geschwindigkeitszuwachs spüren.


== Pfad-Cache ==
== Installation ==
''hash'' ist ein [[:Kategorie:Bash/Builtin|interner Befehl]] der [[Bash]] und muss nicht separat installiert werden
 
== Anwendungen ==
=== Pfad-Cache ===
  $ '''hash'''  
  $ '''hash'''  


Zeile 82: Zeile 28:
* Bei der Gelegenheit wird auch gleich angezeigt, wie oft das Programm gestartet wurde.  
* Bei der Gelegenheit wird auch gleich angezeigt, wie oft das Programm gestartet wurde.  


=== Verwerfen alle gespeicherten Pfade ===
=== Verwerfen alle Pfade ===
  $ '''hash -r'''
  $ '''hash -r'''


Zeile 108: Zeile 54:


=== Pfad zur Tabelle hinzufügen ===
=== Pfad zur Tabelle hinzufügen ===
  $ '''hash -p <Pfad_zum_Kommando>
  $ '''hash -p <Pfad_zum_Kommando>'''
'''
[[Kategorie:Bash:Builtin]]
[[Kategorie:Bash:Interaktiv]]
[[Kategorie:Linux:Befehl]]
{{DEFAULTSORT:hash}}


= TMP =
== Syntax ==
  $ '''hash [-lr] [-p Pfadname] [-dt] [Name ...]'''
  $ '''hash [-lr] [-p Pfadname] [-dt] [Name ...]'''


Programpfade merken oder anzeigen.
=== Optionen ===
{| class="wikitable sortable options"
|-
! Option !! Beschreibung
|-
| -d || Vergessen des Speicherortes für jeden NAME
|-
| -l || Anzeige in einem Format, das als Eingabe wiederverwendet werden kann
|-
| -p || Pfadname verwendet PATHNAME als den vollständigen Pfadnamen von NAME
|-
| -r || vergisst alle gespeicherten Pfade
|-
| -t || gibt den Speicherort jedes NAMENS aus, wobei jedem Speicherort der entsprechende NAME vorangestellt wird, wenn mehrere NAMEs angegeben sind
|}


Ermittelt und speichert den vollständigen Pfadnamen jedes Kommandos NAME. Wenn keine Argumente angegeben werden, werden Informationen über gespeicherte Kommandod angezeigt.
=== Parameter ===
{| class="wikitable options"
|-
! Option !! Beschreibung
|-
| NAME || Jeder NAME wird in PATH gesucht und in die Liste der gespeicherten Befehle hinzugefügt
|}


== Exit-Status ==
=== Umgebung ===
=== Rückgabewert ===
Gibt Erfolg zurück, es sei denn, NAME wird nicht gefunden oder es wird eine ungültige Option angegeben.
Gibt Erfolg zurück, es sei denn, NAME wird nicht gefunden oder es wird eine ungültige Option angegeben.
== Konfiguration ==
=== Dateien ===
== Sicherheit ==
== Dokumentation ==
=== RFC ===
=== Man-Pages ===
=== Info-Pages ===
== Siehe auch ==
== Links ==
=== Projekt ===
=== Weblinks ===
[[Kategorie:Bash/Builtin]]
[[Kategorie:Bash/Interaktiv]]
[[Kategorie:Linux/Befehl]]
{{DEFAULTSORT:hash}}

Aktuelle Version vom 21. September 2024, 22:42 Uhr

hash - Verwaltung der Hash-Tabelle für Kommando-Pfade

Beschreibung

Programmpfade merken oder anzeigen
  • Ermittelt und speichert den vollständigen Pfadnamen jedes Kommandos NAME
  • Wenn keine Argumente angegeben werden, werden Informationen über gespeicherte Kommandos angezeigt
Ein angegebenes Kommando muss von der Shell gesucht werden
  • Die Suche, vor allem wenn sie die Angaben aus PATH einschließt, kostet Zeit.
  • Deswegen merkt sich die Bash die Zugriffspfade zu allen externen Kommandos in einer Hashtabelle.
Hashtabelle wird zuerst konsultiert
  • Nur wenn der Pfad zu einem Kommando dort nicht erfasst wird, werden die Verzeichnispfade durchsucht
    • Es sei denn hashall ist nicht gesetzt (siehe set)
  • Beim nächsten Zugriff auf das Kommando wird haman den Geschwindigkeitszuwachs spüren.

Installation

hash ist ein interner Befehl der Bash und muss nicht separat installiert werden

Anwendungen

Pfad-Cache

$ hash 
  • (ohne Parameter) zeigt die Liste der gemerkten Pfade zu den Programmen an.
  • Um die Zugriffe auf Programme zu beschleunigen, verwaltet die Bash einen internen Cache der Pfade auf bereits gestartete Programme.
  • Wird ein Programm erneut gestartet, kann die zeitaufwendige Suche entlang des Pfades entfallen.
  • Bei der Gelegenheit wird auch gleich angezeigt, wie oft das Programm gestartet wurde.

Verwerfen alle Pfade

$ hash -r

Anzeige der Hashtabelle

$ hash
hits    command
   2    /bin/ls
   1    /bin/mv
   6    /bin/sh
   8    /usr/bin/vi
   1    /bin/chmod
   3    /bin/date
   1    /usr/bin/id
   1    /usr/bin/man

Gleichnamigen Kommandos

  • Liegt eines in der Hashtabelle vor, so kann auf das andere nur über die vollständige Pfadangabe zugegriffen werden
  • Soll dieses "benachteiligte" Kommando nun vermehrt eingesetzt werden, ist ein Löschen der Hashtabelle mittels »-r« sinnvoll
$ hash -r
$ hash
hash: hash table empty

Indem »hash« mit einem oder mehreren Kommandonamen aufgerufen wird, werden diese Kommandos gesucht und in die Hashtabelle aufgenommen; sie werden jedoch nicht gestartet (sinnvoll ist dies eventuell in Startskripten).

Pfad zur Tabelle hinzufügen

$ hash -p <Pfad_zum_Kommando>

Syntax

$ hash [-lr] [-p Pfadname] [-dt] [Name ...]

Optionen

Option Beschreibung
-d Vergessen des Speicherortes für jeden NAME
-l Anzeige in einem Format, das als Eingabe wiederverwendet werden kann
-p Pfadname verwendet PATHNAME als den vollständigen Pfadnamen von NAME
-r vergisst alle gespeicherten Pfade
-t gibt den Speicherort jedes NAMENS aus, wobei jedem Speicherort der entsprechende NAME vorangestellt wird, wenn mehrere NAMEs angegeben sind

Parameter

Option Beschreibung
NAME Jeder NAME wird in PATH gesucht und in die Liste der gespeicherten Befehle hinzugefügt

Umgebung

Rückgabewert

Gibt Erfolg zurück, es sei denn, NAME wird nicht gefunden oder es wird eine ungültige Option angegeben.

Konfiguration

Dateien

Sicherheit

Dokumentation

RFC

Man-Pages

Info-Pages

Siehe auch

Links

Projekt

Weblinks