在命令行上运行可执行文件没问题,但通过另一个程序运行会导致无响应

问题描述 投票:0回答:1

在 Windows 命令提示符下运行可执行文件以及参数就可以了:

cgx_STATIC.exe -b C:\Users\m3\AppData\Local\Temp\shot-277325955.fbd

但是,当通过 Golang 运行相同的可执行文件时,在可执行文件创建一些输出文件后,可执行文件将变得无响应。


// Run an executable and print its log into a file.
func RunWithLogFile(pthExe string, arg []string, fLog *os.File) error {
    cmd := exec.Command(pthExe, arg...)

    stdout, err := cmd.StdoutPipe()
    if err != nil {
        return err
    }
    stderr, err := cmd.StderrPipe()
    if err != nil {
        return err
    }

    err = cmd.Start()
    if err != nil {
        return err
    }

    // Stream logs:
    // https://stackoverflow.com/a/48849811/3405291
    scannerOut := bufio.NewScanner(stdout)
    scannerErr := bufio.NewScanner(stderr)
    scannerOut.Split(bufio.ScanRunes)
    scannerErr.Split(bufio.ScanRunes)
    for scannerOut.Scan() {
        _, err = fLog.WriteString(scannerOut.Text())
        if err != nil {
            return err
        }
    }
    for scannerErr.Scan() {
        _, err = fLog.WriteString(scannerErr.Text())
        if err != nil {
            return err
        }
    }
    if scannerOut.Err() != nil {
        return err
    }
    if scannerErr.Err() != nil {
        return err
    }

    err = cmd.Wait()
    return err
}

我想知道上面的 Go 代码是否存在某种错误或不适合运行可执行文件?

单独的 goroutine

按照@BurakSerdar的建议,我在单独的goroutines中从stdout和stderr读取,但问题没有得到解决:


// Run an executable and print its log into a file.
func RunWithLogFile(pthExe string, arg []string, fLog *os.File) error {
    cmd := exec.Command(pthExe, arg...)

    stdout, err := cmd.StdoutPipe()
    if err != nil {
        return err
    }
    stderr, err := cmd.StderrPipe()
    if err != nil {
        return err
    }

    var wg sync.WaitGroup
    wg.Add(2)

    go streamToLogFile(stdout, fLog, &wg)
    go streamToLogFile(stderr, fLog, &wg)

    err = cmd.Start()
    if err != nil {
        return err
    }

    wg.Wait()

    err = cmd.Wait()
    return err
}

func streamToLogFile(output io.ReadCloser, fLog *os.File, wg *sync.WaitGroup) {
    defer wg.Done()
    scanner := bufio.NewScanner(output)
    scanner.Split(bufio.ScanRunes)
    for scanner.Scan() {
        _, err := fLog.WriteString(scanner.Text())
        if err != nil {
            log.Printf("error: write to log file: %s", err.Error())
        }
    }
    err := scanner.Err()
    if err != nil {
        log.Printf("error: write to log file: %s", err.Error())
    }
}
windows go command-line executable
1个回答
0
投票

通过以批处理模式运行可执行文件解决了无响应问题。研究文档

但是您需要一台具有图形功能的计算机,因为 cgx 需要它 即使没有请求图形输出。尽管如此,图形的弹出 可以通过使用

-bg
参数启动 cgx 来抑制窗口。在这个 模式下,由于不执行与图形相关的操作,因此性能更高。

因此,使用

-bg
运行可执行文件解决了问题。

© www.soinside.com 2019 - 2024. All rights reserved.