(sed's/^/lineofoutput:/')doneL'utilisateur peut saisir quelque chose comme sleep5 Une telle commande de premier plan ; echohi bloquera et l'invite ne réapparaîtra pas immédiatement, ou ils peuvent entrer une commande d'arrière-plan comme"/> (sed's/^/lineofoutput:/')doneL'utilisateur peut saisir quelque chose comme sleep5 Une telle commande de premier plan ; echohi bloquera et l'invite ne réapparaîtra pas immédiatement, ou ils peuvent entrer une commande d'arrière-plan comme">
Maison >développement back-end >Golang >Comment exécuter des commandes shell au premier plan ou en arrière-plan dans Go
Éditeur php Apple vous présente comment exécuter des commandes shell en façade ou en arrière-plan dans Go. En langage Go, exécuter des commandes shell est très simple. En utilisant le package os/exec, nous pouvons facilement exécuter diverses commandes shell et obtenir leur sortie. Qu'il s'agisse d'exécuter des commandes de premier plan ou des commandes d'arrière-plan, le langage Go fournit les méthodes correspondantes. Dans cet article, nous apprendrons comment exécuter des commandes shell avant ou en arrière-plan à l'aide du langage Go et explorerons quelques cas d'utilisation courants. commençons!
En go, je dois pouvoir exécuter des commandes shell à partir de l'utilisateur et bloquer uniquement les commandes qui s'exécutent au premier plan (et non exécutées avec &
), tout en récupérant le résultat de la commande.
Par exemple, en bash on peut :
#!/bin/bash while read -p 'enter a command: ' cmd; do /bin/sh -c "$cmd" >(sed 's/^/line of output: /') done
Les utilisateurs peuvent taper quelque chose comme sleep 5这样的前台命令; echo hi
会阻塞并且提示不会立即重新出现,或者他们可以输入后台命令,如 { sleep 5;回声嗨; &
et cela ne bloquera pas et l'invite réapparaîtra immédiatement pendant que la commande s'exécute en arrière-plan.
Comment puis-je le recréer en go ? Voici ma tentative :
package main import ( "bufio" "os" "os/exec" ) func main() { input := bufio.newscanner(os.stdin) for { print("enter a command: ") input.scan() cmd := exec.command("/bin/sh", "-c", input.text()) stdout, err := cmd.stdoutpipe() if err != nil { panic(err) } go func() { output := bufio.newscanner(stdout) for output.scan() { println("line of output: " + output.text()) } if output.err() != nil { panic(output.err()) } }() if err := cmd.start(); err != nil { panic(err) } if err := cmd.wait(); err != nil { panic(err) } } }
Exécuter sleep 5; echo hi
会阻塞并且可以工作,但是 { sleep 5;回声嗨; } &
Erreur :
panic: read |0: file already closed
Pour le contexte, j'ai porté la commande vocale pour aller là où l'utilisateur peut la configurer runtype
等操作,其中他们的命令通过 shell 运行,并模拟按键以键入输出。用户可以使用后台命令,以便语音控制与命令一起继续,例如,他们可以在说出“菜单”时启动菜单,并且在打开时仍然能够使用语音控制: menu: runtype printf %s\n 这个那个 | dmenu &
.
Définissez stdout sur un canal nommé pour obtenir ce comportement.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!