调用子进程,例子调用脚本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()
}