首页 > 系统服务 > 详细

golang执行命令实时输出(协程通过channel更新数据到主进程)

时间:2020-11-02 21:03:20      阅读:58      评论:0      收藏:0      [点我收藏+]
func TestCmdOut(t *testing.T) {
	fmt.Println("start")
	cmdstr := "dir /s C:"
	cmd := exec.Command("cmd","/c",cmdstr)
	fmt.Println("11111111")
	stdout,err := cmd.StdoutPipe()
	if err != nil {
		fmt.Println(err)
		return
	}
	stderr,err := cmd.StderrPipe()
	if err != nil {
		fmt.Println(err)
		return
	}

	err = cmd.Start()

	if err != nil {
		fmt.Println(err)
	}

	stdoutScanner := bufio.NewScanner(stdout)
	stderrScanner := bufio.NewScanner(stderr)
	charset := GB18030

	totalOut := ""
	totalErr := ""
	outChan :=  make(chan string, 10000)
	errChan :=  make(chan string, 10000)
	exeEnd := false
	go func(scanner *bufio.Scanner) {
		for scanner.Scan() {
			stdoutstr := ConvertByte2String(scanner.Bytes(), charset)
			outChan <- stdoutstr
		}
		exeEnd = true
	}(stdoutScanner)

	go func(scanner *bufio.Scanner) {
		for scanner.Scan() {
			stderrstr := ConvertByte2String(scanner.Bytes(), charset)
			errChan <- stderrstr
		}
	}(stderrScanner)

	j := 0
	for {
		for i:=0;i<10000;i++ {
			select {
			case outTemp :=  <- outChan:
				fmt.Println("chan:"+outTemp)
				totalOut += "\n" + outTemp
			default:
				fmt.Println(fmt.Sprintf("j:%d",j))
				fmt.Println("direct end")
				goto outexit
			}
		}
		outexit:
		for i:=0;i<10000;i++ {
			select {
			case errTemp := <- errChan:
				totalErr += "\n" + errTemp
			default:
				fmt.Println("err direct end")
				goto errexit
			}
		}
		errexit:

		fmt.Println(fmt.Sprintf("totalOut:%s",totalOut))
		fmt.Println(fmt.Sprintf("totalErr:%s",totalErr))
		time.Sleep(1*time.Second)
		fmt.Println(exeEnd)
		if exeEnd {
			j += 1
		}
		if j>=2 {
			break
		}


	}

	err = cmd.Wait()


}

  

golang执行命令实时输出(协程通过channel更新数据到主进程)

原文:https://www.cnblogs.com/zipon/p/13915541.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!