我想构建一个类似于 unix tool 的基准测试工具time。我目前拥有的是:
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)
}
我的问题是,输出不是流式传输,而是一次全部打印出来,奇怪的是,对于某些程序根本没有。
郎朗坤
相关分类