dispatchQueue.global(qos: .userInitiated).async { let server:UDPServer=UDPServer(address:"0.0.0.0",port:5005) let (data,_,_) = server.recv(1024) dispatchQueue.main.async { ... }}
这完美无缺,并启动了一个等待我的数据进入的过程.如果我们永远不会得到回复,会让我夜不能寐? server.recv永远不会返回,所以我无法看到这个过程将如何结束?有没有办法让它有一定的时间来竞选?
解决方法 无法从外部停止或“杀死”dispatchWorkItem或NSOperation.有一个cancel()方法,但只是将item或operation的isCancelled属性设置为true.这不会停止项目本身的执行. Ans因为recv被阻塞,所以在执行期间无法检查isCancelled标志.这意味着Vadian发布的答案很遗憾不会做任何事情.根据NSOperation上的Apple docs.cancel:
This method does not force your operation code to stop.
The same适用于NSOperationQueue.cancelAllOperations:
Canceling the operations does not automatically remove them from the queue or stop those that are currently executing.
您可能认为可以下拉到使用原始NSThread.但是,同样的原则适用于hIEr.你无法确定性地从外部杀死一个线程.
可能的解决方案:超时
我能想到的最好的解决方案是使用套接字的超时功能.我不知道UDPServer来自哪里,但也许它有一个内置的超时.
可能的解决方案:穷人的超时(发送数据包到localhost)
您可以尝试的另一个选项是在经过一段时间后向您自己发送一些UDP数据包.这样,recv将接收一些数据,并继续执行.这可能被用作“穷人的超时”.
总结以上是内存溢出为你收集整理的Swift取消DispatchQueue流程全部内容,希望文章能够帮你解决Swift取消DispatchQueue流程所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)