30Jul
När du skapar ett nytt skalskript vill du se till att det är så problemfritt som möjligt, men ibland kan det vara lite förvirrande att veta vilken shebang är den bästa för dig att använda. På den noten har dagens SuperUser Q & A-inlägg svaret på en förvirrad läsares fråga.
Dagens fråga &Svarssession kommer till oss med tillstånd av SuperUser-en indelning av Stack Exchange, en community-driven gruppering av Q & A-webbplatser.
Frågan
SuperUser-läsare Hendre vill veta när det är bättre att använda #!/bin/ bash istället för #!/bin/ sh i skalskript:
När är det lämpligare att använda #!/bin/ bash snarare än #!/bin/ sh i ett skalskript?
När är det bättre att använda #!/bin/ bash istället för #!/bin/ sh i ett skalskript?
Svaret
SuperUser-bidragsgravitat har svaret för oss:
Kort sagt:
- Det finns flera skal som implementerar en superset av POSIX sh-specifikationen. På olika system kan /bin/ sh vara en länk till aska, bash, dash, ksh, zsh, etc. Det kommer alltid att vara sh-kompatibel men aldrig csh eller fisk.
- Så länge du bara håller fast vid Sh-funktioner kan du( och förmodligen även) använda #!/bin/ sh och manuset ska fungera bra, oavsett vilket skal det är.
- Om du börjar använda bash-specifika funktioner( dvs. arrayer), bör du specifikt begära bash eftersom även om /bin/ sh redan påkallar bash på ditt system, kanske det inte finns på alla andras system och ditt skript kommer inte att springa där. Detsamma gäller för zsh och ksh, förstås.
- Även om manuset endast är avsett för personligt bruk kanske du märker att vissa operativsystem ändrar /bin/ sh under uppgraderingar. Till exempel, på Debian brukade den vara bash, men ersattes senare med den mycket minimala streckkoden. Skript som använde bashism men hade #!/bin/ sh bröt plötsligt.
Men:
- Även #!/bin/ bash är inte så korrekt. På olika system kan bash leva i /usr/ bin , /usr/pkg/ bin eller /usr/local/ bin .
- Ett mer tillförlitligt alternativ är #!/usr/bin/ env bash , som använder $ PATH .Även om env-verktyget självt inte är strikt garanterat, fungerar /usr/bin/ env fortfarande på fler system än /bin/ bash gör.
Har du något att lägga till förklaringen? Ljud av i kommentarerna. Vill du läsa mer svar från andra tech-savvy Stack Exchange-användare? Kolla in hela diskussionsgängan här.
Bildkrediter: Wikipedia