Contents

removeTimeObserver(_:)

Cancels a previously registered periodic or boundary time observer.

Declaration

nonisolated func removeTimeObserver(_ observer: Any)

Parameters

Mentioned in

Discussion

Upon return, the caller is guaranteed that no new time observer blocks will begin executing. Depending on the calling thread and the queue used to add the time observer, an in-flight block may continue to execute after this method returns. You can guarantee synchronous time observer removal by enqueuing the call to removeTimeObserver on that queue. Alternatively, call dispatch_sync(queue, ^{}) after removeTimeObserver to wait for any in-flight blocks to finish executing.

You should use this method to explicitly cancel each time observer added using addPeriodicTimeObserver(forInterval:queue:using:) and addBoundaryTimeObserver(forTimes:queue:using:).

The following shows a common implementation to remove a registered time observer:

See Also

Observing playback time