草庐IT

dispatch-async

全部标签

objective-c - performSelectorOnMainThread : and dispatch_async() on main queue? 有什么区别

我在修改线程内的View时遇到问题。我尝试添加一个subview,但显示需要大约6秒或更长时间。我终于让它工作了,但我不知Prop体如何。所以我想知道它为什么起作用以及以下方法之间有什么区别:这有效-立即添加了View:dispatch_async(dispatch_get_main_queue(),^{//someUImethodsej[viewaddSubview:otherView];}这需要大约6秒或更长时间才能显示:[viewControllerperformSelectorOnMainThread:@selector(methodThatAddsSubview:)withO

objective-c - 为什么我们不能在当前队列上使用 dispatch_sync?

我遇到了一个场景,我有一个委托(delegate)回调,它可能发生在主线程或另一个线程上,直到运行时我才知道是哪个(使用StoreKit.framework)。我还有需要在回调中更新的UI代码,这需要在函数执行之前发生,所以我最初的想法是有一个这样的函数:-(void)someDelegateCallback:(id)sender{dispatch_sync(dispatch_get_main_queue(),^{//uiupdatecodehere});//codeherethatdependsupontheUIgettingupdated}当它在后台线程上执行时,效果很好。但是,当

python - multiprocessing.Pool : When to use apply, apply_async 或映射?

我还没有看到关于Pool.apply用例的明确示例,Pool.apply_async和Pool.map.我主要使用Pool.map;别人的优点是什么? 最佳答案 在Python的旧时代,要调用带有任意参数的函数,您可以使用apply:apply(f,args,kwargs)apply在Python2.7中仍然存在,但在Python3中没有,一般不再使用。如今,f(*args,**kwargs)是首选。multiprocessing.Pool模块尝试提供类似的接口(interface)。Pool.apply与Pythonapply类似

c# - Await 运算符只能在 Async 方法中使用

这个问题在这里已经有了答案:Can'tspecifythe'async'modifieronthe'Main'methodofaconsoleapp(19个回答)关闭5年前。我正在尝试制作一个简单的程序来测试VisualStudio2012中新的.NET异步功能。我通常使用BackgroundWorkers来异步运行耗时的代码,但有时对于相对简单(但昂贵)操作。新的async修饰符看起来很好用,但不幸的是我似乎无法进行简单的测试。这是我在C#控制台应用程序中的代码:staticvoidMain(string[]args){stringMarsResponse=awaitQueryRov

javascript - 将 redux-saga 与 ES6 生成器结合使用与 redux-thunk 与 ES2017 async/await 结合使用的优缺点

现在有很多关于redux镇最新小子的讨论,redux-saga/redux-saga.它使用生成器函数来监听/调度Action。在深入了解它之前,我想知道使用redux-saga的优缺点而不是下面我使用redux-thunk的方法使用异步/等待。一个组件可能看起来像这样,像往常一样调度操作。import{login}from'redux/auth';classLoginFormextendsComponent{onClick(e){e.preventDefault();const{user,pass}=this.refs;this.props.dispatch(login(user.v

javascript - 哪些浏览器支持<script async ="async"/>?

2009年12月1日,Google宣布支持asynchronousGoogleAnalyticstracking.异步跟踪是使用的async指令实现的。标记。哪些浏览器支持异步指令()以及从哪个版本开始? 最佳答案 google指定的异步支持是通过两个部分实现的:使用页面上的脚本(该脚本由google提供)将标签写入DOM。该脚本具有async="true"属性以向兼容的浏览器发出信号,表明它可以继续呈现页面。第一部分适用于不支持的浏览器标签,允许他们通过“hack”(虽然相当可靠)加载异步,并且还允许在不等待ga.js被检索的情况

ruby - perform_async 在 sidekiq 中不起作用

我正在尝试使用sidekiq在后台处理一些请求(它与padrino框架集成)。我的期望是,一旦调用了worker,请求处理程序会立即将答案返回给用户。为了确保它正常工作,我实现了一个worker,它会在完成处理之前打印一些消息并休眠大约44秒(以模拟后台的长时间处理)。令我惊讶的是,请求一直卡在工作人员完成工作之前。只有在那之后,请求处理程序才能向用户返回答案。起初我认为sleep函数可能是问题所在,所以我将sleep函数替换为忙碌的一段时间,但我有相同的行为:请求处理程序挂起,直到工作人员完成其任务。知道为什么会这样吗?您可以看到以下内容:请求处理程序:get:hardworker,

ruby-on-rails - `dispatch_request' : 在 Net::SFTP.upload 期间没有这样的请求

我正在使用Net::SFTP将文件上传到服务器。这是代码:uri=URI.parse('sftp://host.org')io=StringIO.new(csv_string)timeout120doNet::SFTP.start(uri.host,ENV['SFTP_USER'],:password=>ENV['SFTP_PASS'],:port=>22)do|sftp|sftp.upload(io,"/ftpguest/Medstro/"+file_name)endend当我运行代码时,它成功连接到主机并上传了一个具有正确文件名的零字节文件。然后它抛出这个异常:lib/ruby/g

ruby 事件机器 + AMQP : Ensuring specific async calls happen before raising exceptions

我们正在用Ruby构建一个支持AMQP的消息传递系统。但是,我们在错误处理方面遇到了问题。我们维护一个异常白名单,这是安全的,并且RabbitMQ中的消息可以不被确认并由另一个工作人员重试。然而,对于未知或不可预见的错误,我们假设无论工作人员尝试消息多少次,同样的失败总是会发生。这意味着,当出现未知错误时,我们需要捕获它,将其记录在某个地方(目前是MySQL),然后向RabbitMQ发送一个ACK调用以从队列中删除消息。目前一切都是使用amqpgem构建的,它是用EventMachine触发的。这会导致问题,因为调用#ack方法,并不意味着ACK由于gem的异步行为已发送到Rabbit

ruby-on-rails - sidekiq 中的 perform_in 和 perform_async 有什么区别?

我想用新的时间间隔更新旧的sidekiq作业。我该怎么做?是否可以通过perform_in选项。此外,我想知道perform_in和perform_async之间的明显区别。 最佳答案 您必须通过perform_in一次。perform_async立即被推送到队列中。除此之外,它们是相同的。你会调用perform_in(10.minutes) 关于ruby-on-rails-sidekiq中的perform_in和perform_async有什么区别?,我们在StackOverflow上