BatchHandle

Struct BatchHandle 

Source
pub struct BatchHandle { /* private fields */ }
Expand description

Batch timer handle for managing batch-scheduled timers

Note: This type does not implement Clone to prevent duplicate cancellation of the same batch of timers. Use into_iter() or into_handles() to access individual timer handles.

批量定时器句柄,用于管理批量调度的定时器

注意:此类型未实现 Clone 以防止重复取消同一批定时器。使用 into_iter()into_handles() 访问单个定时器句柄。

Implementations§

Source§

impl BatchHandle

Source

pub fn cancel_all(self) -> usize

Cancel all timers in batch

§Returns

Number of successfully cancelled tasks

批量取消所有定时器

§返回值

成功取消的任务数量

§Examples (示例)
let timer = TimerWheel::with_defaults();
let delays: Vec<Duration> = (0..10)
    .map(|_| Duration::from_secs(1))
    .collect();
let tasks = TimerWheel::create_batch(delays);
let batch = timer.register_batch(tasks);
 
let cancelled = batch.cancel_all();
println!("Canceled {} timers", cancelled);
Source

pub fn into_handles(self) -> Vec<TimerHandle>

Convert batch handle to Vec of individual timer handles

Consumes BatchHandle and creates independent TimerHandle for each task

将批量句柄转换为单个定时器句柄的 Vec

消费 BatchHandle 并为每个任务创建独立的 TimerHandle

§Examples (示例)
let timer = TimerWheel::with_defaults();
let delays: Vec<Duration> = (0..3)
    .map(|_| Duration::from_secs(1))
    .collect();
let tasks = TimerWheel::create_batch(delays);
let batch = timer.register_batch(tasks);
 
// Convert to individual handles
// 转换为单个句柄
let handles = batch.into_handles();
for handle in handles {
    // Can operate each handle individually
    // 可以单独操作每个句柄
}
Source

pub fn len(&self) -> usize

Get the number of batch tasks

获取批量任务数量

Source

pub fn is_empty(&self) -> bool

Check if batch tasks are empty

检查批量任务是否为空

Source

pub fn task_ids(&self) -> &[TaskId]

Get reference to all task IDs

获取所有任务 ID 的引用

Source

pub fn completion_receivers( &mut self, ) -> &mut Vec<Receiver<TaskCompletionReason>>

Get reference to all completion receivers

§Returns

Reference to list of completion receivers for all tasks

获取所有完成通知接收器的引用

§返回值

所有任务完成通知接收器列表的引用

Source

pub fn into_completion_receivers(self) -> Vec<Receiver<TaskCompletionReason>>

Consume handle and return all completion receivers

§Returns

List of completion receivers for all tasks

消费句柄并返回所有完成通知接收器

§返回值

所有任务的完成通知接收器列表

§Examples (示例)
let timer = TimerWheel::with_defaults();
let delays: Vec<Duration> = (0..3)
    .map(|_| Duration::from_secs(1))
    .collect();
let tasks = TimerWheel::create_batch(delays);
let batch = timer.register_batch(tasks);
 
// Get all completion receivers
// 获取所有完成通知接收器
let receivers = batch.into_completion_receivers();
for rx in receivers {
    tokio::spawn(async move {
        if rx.await.is_ok() {
            println!("A timer completed!");
        }
    });
}

Trait Implementations§

Source§

impl IntoIterator for BatchHandle

Implement IntoIterator to allow direct iteration over BatchHandle

实现 IntoIterator 以允许直接迭代 BatchHandle

§Examples (示例)

let timer = TimerWheel::with_defaults();
let delays: Vec<Duration> = (0..3)
    .map(|_| Duration::from_secs(1))
    .collect();
let tasks = TimerWheel::create_batch(delays);
let batch = timer.register_batch(tasks);
 
// Iterate directly, each element is an independent TimerHandle
// 直接迭代,每个元素是一个独立的 TimerHandle
for handle in batch {
    // Can operate each handle individually
    // 可以单独操作每个句柄
}
Source§

type Item = TimerHandle

The type of the elements being iterated over.
Source§

type IntoIter = BatchHandleIter

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.