doucuo4413 2015-06-26 20:13
浏览 25
已采纳

流os / exec.Command

I want to build a benchmarking tool similar to the unix tool time. What I currently have is this:

package main

import (
    "fmt"
    "os"
    "os/exec"
    "time"
)

func main() {
    command := os.Args[1]
    args := os.Args[2:]
    cmd := exec.Command(command, args...)
    start_time := time.Now().UnixNano()
    stdout, err := cmd.Output()

    if err != nil {
        println(err.Error())
        return
    }

    print(string(stdout))
    total_time := int64(time.Nanosecond) * (time.Now().UnixNano() - start_time) / int64(time.Millisecond)
    fmt.Println(total_time)
}

My problem with this is, that the output is not streaming, instead it is printed all at once, and weirdly enough for some programs not at all.

  • 写回答

2条回答 默认 最新

  • duanjiao6735 2015-06-26 20:32
    关注

    The best way is to avoid touching the stream altogether. You can pass your own file descriptors for stdout and stderr directly.

    package main
    
    import (
        "fmt"
        "os"
        "os/exec"
        "time"
    )
    
    func main() {
        command := os.Args[1]
        args := os.Args[2:]
        cmd := exec.Command(command, args...)
        cmd.Stdout = os.Stdout
        cmd.Stderr = os.Stderr
        start_time := time.Now()
    
        err := cmd.Run()
        if err != nil {
            println(err.Error())
            return
        }
    
        total_time := int64(time.Since(start_time) / time.Millisecond)
        fmt.Println(total_time)
    }
    

    Also, print() should never be used. Instead, use one of the fmt.Print* functions.


    total_time := int64(time.Nanosecond) * (time.Now().UnixNano() - start_time) / int64(time.Millisecond)
    

    This line is extremely confusing. int64(time.Nanosecond) * x resolves to 1 * x or just x.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示