我猜默认行为是,当我使用后台工作者实现它时,用户可以取消长时间运行的进程。WorkerSupportCancellation 有什么意义?
如果我不将此 WorkerSupportCancellation 用作 true,用户将无法取消?或者换句话说,是否必须定义 this ?
如果问题一的答案是“非强制性”,那么为什么这是 MS 提出的功能?我认为没有什么好的理由阻止用户取消该过程,这完全取决于他的选择。此功能适合什么场景?
有人可以对此有所了解。
我猜默认行为是,当我使用后台工作者实现它时,用户可以取消长时间运行的进程。WorkerSupportCancellation 有什么意义?
如果我不将此 WorkerSupportCancellation 用作 true,用户将无法取消?或者换句话说,是否必须定义 this ?
如果问题一的答案是“非强制性”,那么为什么这是 MS 提出的功能?我认为没有什么好的理由阻止用户取消该过程,这完全取决于他的选择。此功能适合什么场景?
有人可以对此有所了解。
是的,它必须设置true
为允许异步取消。调用CancelAsync()
已WorkerSupportsCancellation
设置为的 BackgroundWorkerfalse
将导致InvalidOperationException
.
我相信InvalidOperationException
如果你在没有设置它的情况下尝试取消它,它会抛出一个错误,所以它是强制性的。
我能看到以这种方式设计它的唯一原因是让写工作人员的人指出是否可以取消。从逻辑上讲,并非所有BackgroundWorkers
都可以取消,因此使用工人的人可以更轻松地查看是否可以取消。
WorkerSupportCancellation
必须设置为 true 才能支持异步取消。否则调用CancelAsync()
会抛出InvalidOperationException
. 因此,针对您的问题:
是的,这必须是真实的,用户才能取消。仅当必须具有取消能力时才具有强制性。
根据您的应用程序的要求,您可能希望在后台执行一项任务,例如数据库查询、与文件系统交互等……这些任务必须完成并且可能不是由用户发起的。因此,在某些情况下,可能不需要异步取消,因为大多数用户发起的操作取消是一个很好的支持特性。