在用Go的exec啟動子進程的時候,類似於date命令之類的子進程,命令執行完,可以等子進程執行完成後獲取子進程的輸出。 ``` package main import ( "fmt" "log" "os/exec" ) func main() { out, err := exec.command("date").Output() if err != nil { log.Fatal(err) } fmt.Printf("The date is %s\n", out) } ``` 但是,如果子進程是類似於top這類常駐內存的子進程怎麽辦的,官方的手冊並沒有給出例子,最近我在做一個小工具的時候,需要獲取常駐內存子進程的輸出,找到了解決方案 ``` package main import ( "os/exec" "os" "bytes" "log" "time" "fmt" ) func main() { cmd := exec.Command("top") cmd.Stdin = os.Stdin var out bytes.Buffer cmd.Stdout = &out cmd.Stderr = &out go func() { for { l, err := out.ReadString('\n') if err != nil && err.Error() != "EOF" { log.Print(err) time.Sleep(100 * time.Millisecond) continue } fmt.Print(l) time.Sleep(100 * time.Millisecond) } }() cmd.Run() } ``` 這樣就可以持續獲取子進程的輸出了
Tags: 進程 常駐 輸出 獲取 err exec
文章來源: