golang如何获取子进程的实时输出

调用子进程,例子调用脚本script.sh并实时的得到子进程的输出。
确实情况下父进程要等到子进程完成之后,一次性得到所有输出。

package main

import (
    "bufio"
    "fmt"
    "io"
//  "os"
    "os/exec"
)

func main() {
    handleStdout := func(r io.Reader) {
        fmt.Println("handleStdout entry")
        //io.Copy(os.Stdout, r)
        s := bufio.NewScanner(r)
        for s.Scan() {
            line := s.Text()
            fmt.Println(line)
        }
        if err := s.Err(); err != nil {
            fmt.Println(err)
        }
        fmt.Println("handleStdout exit")
    }

    cmd := exec.Command("bash", "script.sh")
    stdout, _ := cmd.StdoutPipe()
    go handleStdout(stdout)
    cmd.Start()
    cmd.Wait()
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容