为执行的进程创建繁忙指示器
执行需要较长持续时间的子进程时,为用户提供一种了解方式至关重要该进程确实正在运行。如果没有指示器,用户可能无法意识到进度,甚至认为系统已变得无响应。
为了解决此问题,可以实现各种忙碌指示器来向用户提供视觉提示。其中一个指示器涉及定期将一个字符(例如点或进度条)打印到控制台。
使用 Goroutines 作为繁忙指示器
Goroutines 是轻量级线程Go 编程语言,可用于创建一个单独的线程,负责管理繁忙指示器。下面是如何实现这一点:
<code class="go">func indicator(shutdownCh <-chan struct{}) { ticker := time.NewTicker(time.Second) defer ticker.Stop() for { select { case <-ticker.C: fmt.Print(".") case <-shutdownCh: return } } } func main() { cmd := exec.Command("npm", "install") log.Printf("Running command and waiting for it to finish...") // Start indicator: shutdownCh := make(chan struct{}) go indicator(shutdownCh) err := cmd.Run() close(shutdownCh) // Signal indicator() to terminate fmt.Println() log.Printf("Command finished with error: %v", err) }</code>
在这个例子中,创建了一个名为indicator()的goroutine,它定期向控制台打印一个点。 Goroutine 继续打印,直到从 shutdownCh 通道接收到信号。当子进程完成时,主 Goroutine 关闭 shutdownCh,导致 Indicator() Goroutine 终止并停止打印点。
自定义 Busy Indicators
Busy Indicator 可以通过调整打印速率或添加不同的字符或图案来进一步定制。例如,要每秒打印一个点并在每 5 个点后打印一个新行,可以按如下方式修改 Indicator() 函数:
<code class="go">func indicator(shutdownCh <-chan struct{}) { ticker := time.NewTicker(time.Second) defer ticker.Stop() for i := 0; ; { select { case <-ticker.C: fmt.Print(".") if i++; i%5 == 0 { fmt.Println() } case <-shutdownCh: return } } }</code>
通过在应用程序中合并繁忙指示器,您可以提供为用户提供响应更快、用户友好的体验,确保他们在等待结果时进程正在后台执行。
以上是如何使用 goroutine 为 Go 中长时间运行的进程创建繁忙指示器?的详细内容。更多信息请关注PHP中文网其他相关文章!