Golang의 Ticker Stop 동작
Golang의 Ticker 패키지를 사용할 때 Stop()의 동작과 그 영향을 이해하는 것이 중요합니다. 관련 채널에서. Stop()을 호출하면 티커 방출이 효과적으로 중지되지만 채널은 닫히지 않습니다.
예제를 고려하세요.
package main import ( "time" "log" ) func main() { ticker := time.NewTicker(1 * time.Second) go func(){ for _ = range ticker.C { log.Println("tick") } log.Println("stopped") }() time.Sleep(3 * time.Second) log.Println("stopping ticker") ticker.Stop() time.Sleep(3 * time.Second) }
이 코드는 예상치 못한 동작을 보여줍니다. 티커 채널은 Ticker.Stop()을 사용하여 중지되지만 해당 고루틴은 활성 상태로 유지됩니다. 이는 고루틴의 지속적인 존재가 바람직하지 않으며 이러한 상황을 처리하는 최선의 접근 방식인지에 대한 우려를 불러일으킵니다.
중지용 두 번째 채널 사용
한 가지 효과적인 해결책은 다음과 같습니다. 특히 티커에 중지 신호를 보내기 위한 두 번째 채널입니다.
package main import ( "log" "time" ) // Every runs the provided function periodically, allowing the function to control when to stop. func Every(duration time.Duration, work func(time.Time) bool) chan bool { ticker := time.NewTicker(duration) stop := make(chan bool, 1) // Channel for signaling stop go func() { defer log.Println("ticker stopped") for { select { case time := <-ticker.C: if !work(time) { // Function decides to stop stop <- true } case <-stop: // Signal to stop has been received return } } }() return stop } func main() { stop := Every(1*time.Second, func(time.Time) bool { log.Println("tick") return true }) time.Sleep(3 * time.Second) log.Println("stopping ticker") stop <- true // Send the stop signal on the stop channel time.Sleep(3 * time.Second) }
이 수정된 코드에서, Every() 함수는 지속 시간과 계속할지 여부를 나타내는 부울 값을 반환하는 함수를 모두 사용합니다. 중지 채널은 티커 고루틴에 중지 신호를 전달하여 정상적으로 종료되도록 하는 데 사용됩니다.
위 내용은 Golang 티커 고루틴을 정상적으로 종료하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!