首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏CPP开发前沿

    【C++11】 让多线程开发变得简单--异步操作

    C++ 11中提供了异步操作相关类和函数,不同的类具备不同的功能,总体来说类主要有:std::future,std::promise,std::package_task,函数主要是std::async。 1 异步操作类 上面三个类的主要功能是: std::future:该类主要作为异步结果传输通道,方便获取线程函数的返回值; std::promise:用来包装一个值,和futre绑定使用,方便线程赋值; 1.1 std::future 在thread库中提供了该future访问异步操作的结果,由于异步结果不能马上取得,只能在未来某个时候进行获取,这个结果是一个未来值,因此叫做future。 通过查询future状态获取结果,future由三种状态组成,分别是: Deferred:异步操作还没开始 Ready:异步操作已经完成 Timeout:异步操作超时 在实际编码中,可以通过判断这三种内部状态异步获取执行结果 :async 相对前面的异步操作类,std::async要高级的多,且可以直接创建异步的task类,异步返回结果保存在future中,在获取线程函数返回结果时,使用get()获取返回值,如果不需要值则使用

    91630发布于 2021-11-16
  • 来自专栏hotarugaliの技术分享

    JavaScript异步操作

    Promise.all()和Promise.race() 并行调用异步操作 两个函数均用于并行调用多个异步操作使用 All:两个异步操作都resolve之后调用then() var p1 = new Promise p1, p2]).then(function (results) { console.log(results); // 获得一个Array: ['P1', 'P2'] }); Race:最快的异步操作

    63910编辑于 2022-03-01
  • 来自专栏向治洪

    android异步操作

    面对这种异步处理,到底如何写才简洁,先后面临过三种实现方式。 至此,一个典型的异步调用的案例如下: this.doAsync(new Callable<String>() {   // 希望异步加载的数据 public String call() throws "GBK");   return resu;               }           }, new Callback<String>() {   // 当加载完成后回调,在UI线程中的操作 pProgress);   }   public class BaseActivity extends Activity {   /**      *       * @param <T> 模板参数,操作时要返回的内容      * @param pCallable 需要异步调用的操作      * @param pCallback 回调      */ protected <T> void doAsync

    1K80发布于 2018-01-29
  • 来自专栏持续集成

    Nightwatch异步操作

    在自动化测试中常常需要通过一个command(或function)中返回的值来进行下一步的操作,JavaScript与JAVA在调用返回值时有所不同,JS中需要特定的写法来进行这种异步操作。 以下面的得到License数量为例,首先需要获取一次License数量,然后进行一些列操作之后,再一次获取License数量,比较这两次的License数量。

    57450发布于 2020-06-12
  • 来自专栏cywhat

    Django操作异步任务

    INSTALLED_APPS = [ 'celery', 'django_celery_beat', 'django_celery_results' ] 3、新增task 注意 新增的异步任务必须以 worker -l info # 如果看到这行就说明启动成功了 [2023-04-18 15:27:03,191: INFO/MainProcess] celery@cywhat ready. 5、调用异步任务 add.apply_async(args=[3, 5]) 6、安装flower监控 # 安装 pip3 install flower # 运行 celery -A Heng_Tools flower 7、异步任务的一些操作

    1.1K10编辑于 2023-04-27
  • 来自专栏菩提树下的杨过

    几种异步操作方式

    其实这也是面试中被问倒的问题:(贴在这里纪念一下,注:只是简单的罗列,详细原理及分析,请参阅《CLR Via c#》第三版相关章节) 1、利用线程池发起异步操作 using System; using Program { static void Main(string[] args) { Console.WriteLine("主线程:准备发起一系列异步操作 } private static void ComputeBoundOp(object o) { Console.WriteLine("异步操作回调 Program { static void Main(string[] args) { Console.WriteLine("主线程:准备发起一系列异步操作 private static void ComputeBoundOp(object o) { Thread.Sleep(1000);//模拟异步操作在做一些耗时的操作

    87660发布于 2018-01-22
  • 来自专栏小工匠聊架构

    异步编程 - 11 Spring WebFlux的异步非阻塞处理

    相比之下,Spring WebFlux既不是基于Servlet API构建的,也不需要额外的异步请求处理功能,因为它在设计上是异步的。 从这个意义上说,非阻塞是被动的,因为我们现在处于一种模式,即在操作完成或数据可用时对结果做出反应。 (port); server.start(); Tomcat服务器启动后会监听客户端的请求,当请求监听线程接收到完成TCP三次握手的请求后,会把请求交给Tomcat容器内的HTTP处理器(比如Http11Processor 默认情况下,主机(Host)配置为任何本地地址,并且系统在调用绑定操作时可选取临时端口(port)。 下面我们看图7-3中所示步骤11是如何启动服务的。

    3.7K30编辑于 2023-09-09
  • 来自专栏闵开慧

    ajax异步操作1

    ajaxTest.html <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>ajaxTest.html</title> <script type="text/javascript"> function loadXMLDoc(){ var xmlhttp; if(window.XMLHttpRequest){ xmlhttp = new XMLHttpReques

    1.2K80发布于 2018-03-30
  • 来自专栏橙光笔记

    generator处理异步操作

    将数据转化为JSON格式 .then((data)=>{ gen.next(data);// 把data再传回asyncGenFn让他自己打印 }); 上面我们已经把一个异步操作用 generator处理了,我们现在处理2个异步操作,再加一个fetch请求发送后的1秒后打印字符串的一个异步操作。 promise gen.next(val); }); }); }); 这下有没有豁然开朗,异步操作的执行其实是一个套路,就是递归调用gen.next() 此时你貌似懂了点什么,但是你还会问如果不是Promise的异步操作呢?我们先不考虑这种情况,这里假设你很聪明,传的所有的异步操作都是Promise。某大神说:“过早的优化是万恶之源。”。 co 我们用了很少的几行代码写了一个执行器,其实这上面的actuator函数是对大神TJ Holowaychuk所写的co库的拙劣模仿,现在我们可以直接引用co库来实现我们的异步操作: var co

    89430发布于 2020-10-17
  • 来自专栏python3

    aiomysql异步操作mysql

    print(r)     await cur.close()     conn.close() loop.run_until_complete(test_example()) 二、demo演示 环境说明 操作系统 /usr/bin/env python3 # coding: utf-8 """ mysql 异步版本 """ import traceback import logging import aiomysql await self.pool.release(conn)     async def execute(self, query, param=None):         """         增删改 操作 ='xiao1' where id='1'")     # print("exeRtn", exeRtn, type(exeRtn))     if exeRtn:         # print('操作成功 ')         return '操作成功'     else:         # print('操作失败')         return '操作失败' async def main():  

    6.9K21发布于 2020-05-09
  • 来自专栏数据科学(冷冻工厂)

    Python 异步: 等待任务集合(11

    我们可以通过 asyncio.wait() 函数等待异步任务完成。可以等待不同的条件,例如所有任务完成、第一个任务完成以及第一个任务因异常而失败。 让我们仔细看看。 1. 什么是 asyncio.wait() asyncio.wait() 函数可用于等待一组异步任务完成。回想一下,asyncio 任务是包装协程的 asyncio.Task 类的一个实例。

    1.5K10编辑于 2023-02-27
  • 来自专栏数据科学(冷冻工厂)

    Python 异步: 等待任务集合(11

    我们可以通过 asyncio.wait() 函数等待异步任务完成。可以等待不同的条件,例如所有任务完成、第一个任务完成以及第一个任务因异常而失败。 让我们仔细看看。 1. 什么是 asyncio.wait() asyncio.wait() 函数可用于等待一组异步任务完成。回想一下,asyncio 任务是包装协程的 asyncio.Task 类的一个实例。

    2.4K00编辑于 2023-02-23
  • 来自专栏Golang开发

    ES6——异步操作

    有时,我们希望即使前一个异步操作失败,也不要中断后面的异步操作。这时可以将第一个await放在try...catch结构里面,这样不管这个异步操作是否成功,第二个await都会执行。 实例:按顺序完成异步操作 实际开发中,经常遇到一组异步操作,需要按照顺序完成。比如,依次远程读取一组 URL,然后按照读取的顺序输出结果。 Promise 的写法如下。 我们把异步操作包装在一个 async 函数里面,然后调用这个函数,只有等里面的异步操作都执行,变量output才会有值,否则就返回undefined。 上面的代码也可以写成立即执行函数的形式。 它保证只有异步操作完成,模块才会输出值。 也就是说,模块的使用者完全不用关心,依赖模块的内部有没有异步操作,正常加载即可。 这时,模块的加载会等待依赖模块(上例是awaiting.js)的异步操作完成,才执行后面的代码,有点像暂停在那里。

    1.6K40发布于 2019-07-19
  • 来自专栏flutter开发者

    Dart中的异步操作

    借助Future我们可以在Flutter实现异步操作,今天我们就来正式了解下Future。 为什么要用异步 ---- 首先我们知道Dart这门语言是单线程的。 对于耗时的操作(I/O、网络操作等)我们必须要使用异步来处理它们,只有这样,才不会因为这些耗时的操作来影响程序的正常运行。 比如说我们去餐馆吃饭,在等餐的过程中我们一边和朋友聊天,一边玩手机。 但是因为Dart是单线程的所以无论你等待饭来的时间多长,在这个操作没有完成之前他都不会去执行下面的操作,这样就不美好了啊,我在等吃饭的时间内什么也做不了了啊。 上面的例子就是非异步操作引起的问题。 首先我们需要使用async来修饰需要异步处理的方法上,然后使用await来修饰需要异步操作的地方,然后 这个函数就可以返回一个Future对象了。 小结 ---- Dart是单线程的变成语言 使用Future可以是同步操作异步化 Future可以使用async和await来回去 Future可以处理链式调用和多个Future同时返回结果 点击左下角阅读原文

    2.1K20发布于 2019-08-06
  • 来自专栏菩提树下的杨过

    JeffreyZhao]正确使用异步操作

    本想写一点有关LINQ to SQL异步调用的话题,但是在这之前我想还是先写一篇文章来阐述一下使用异步操作的一些原则,避免有些朋友误用导致程序性能反而降低。 这篇文章会讨论一下在.NET中有关异步操作话题,从理论出发结合实际,以澄清概念及避免误用为目标,并且最后提出常见的异步操作场景和使用案例。 这种做法在许多时候会带来各种问题,因此就出现了“异步操作”,但是同样是“异步操作”,不同的任务,不同的情况,它解决问题的方式和带来的效果也是不同的。 在这种的情况下,异步操作并没有提高运算能力或者节省资源(还是需要一个人员的工作),但是提供了较好的用户体验。不过我们这时该怎么利用异步操作呢? ——异步操作不是这样用的。

    912100发布于 2018-01-23
  • 来自专栏武军超python专栏

    异步操作Celery的实现

    celery: 使用场景: 主要用于做异步 1. 解决一些耗时的操作(在原进程继续执行的情况下,开一个新的进程运行比较耗时的程序,让celery去做耗时的事情,给用户一个快速地响应,跑完给一个信号就可以了,不需要让用户等太长时间) 2. 定时执行某些任务 (网站天气定时的更新) celery中的名词: 任务task: 就是一个python函数(要执行的耗时操作) 队列queue: 将需要执行的任务加入到队列中 工人worker: worker: python manage.py celery worker --loglevel=info 然后写视图函数和路由 调用语法: 在视图函数中使用函数名.delay(如果有参数写这里)进行异步调用 使用celery实现异步celery

    1.1K20发布于 2019-02-25
  • 来自专栏想法独特的Dev+Ops

    kubernetes Operator 异步操作方案

    一、核心实现逻辑通过 ctrl.Result 的 定时重试(RequeueAfter) 和 状态标记(Status Conditions) 组合,实现对异步操作全生命周期管理。 = nil { return ctrl.Result{}, err } // 阶段1:初始化异步操作 if obj.Status.Phase == "" { obj.Status.Phase *0.3 + (queueDepth/1000)*0.2 return baseInterval * time.Duration(math.Pow(2, pressureFactor))}}五、异步操作高级模式在 k8s Operator 中集成回调(Callback)与消息队列(Message Queue)是处理异步操作的高级模式,能够显著提升系统的可靠性和实时性。 调用云 API 并注册回调在异步操作(如创建云资源)时,将 Operator 的回调 URL 传递给云服务。

    38900编辑于 2025-03-06
  • 来自专栏忽如寄的前端周刊

    for循环异步操作问题小结

    在实际开发中,异步总是不可逃避的一个问题,尤其是Node.js端对于数据库的操作涉及大量的异步,同时循环又是不可避免的,想象一下一次一个数据组的存储数据库就是一个典型的循环异步操作,而在循环之后进行查询的话就需要确保之前的数据组已经全部存储在了数据库中 可以得到关于循环的异步操作主要有两个问题: 如何确保循环的所有异步操作完成之后执行某个其他操作 循环中的下一步操作依赖于前一步的操作,如何解决 如何确保循环的所有异步操作完成之后执行某个其他操作 方法一 :设置一个flag,在每个异步操作中对flag进行检测 let flag = 0; for(let i = 0; i < len; i++) { flag++; Database.save_method ; i++) { Database.save_method().exec() } }).then(() => { // your code }) 循环中的下一步操作依赖于前一步的操作 ,如何解决 方法一:使用递归,在异步操作完成之后调用下一次异步操作 function loop(i){ i++; Database.save_method().exec().then(() =>

    2.1K20发布于 2019-07-24
  • 来自专栏HarmonyOS点石成金

    鸿蒙开发:异步并发操作

    ,我们就可以继续执行下一个操作,相对于同步而言,异步操作可以同时处理多个任务,不会因为一个任务的耗时而影响其他任务的执行,从而提高了程序的并发处理能力‌,在实际的开发中,特别是应用启动初始化的时候,为了不阻塞程序 ,异步的初始化往往是开发中的首选,在鸿蒙当中,我们如何进行异步的并发操作呢? 简单案例 使用setTimeout函数模拟了一个异步操作。 ,并且提供了一个状态机制来管理异步操作的不同阶段,使用Promise有两个特点,第一个特点,它可以结合async/await,将异步操作转换为类似于同步操作的风格,第二个特点就是,正常的异步操作,使用回调函数来处理成功或失败的结果 三、结合async/await进行使用 async/await是一种用于处理异步操作的Promise语法糖,正如上面所说的,结合使用,可以将异步操作转换为类似于同步操作的风格,比如前言中的案例中,我们使用

    60510编辑于 2025-01-08
  • 来自专栏learn-anything.cn

    JavaScript的异步操作(Promise)

    Promise 是一个用于绑定异步操作与回调函数的对象,让代码更易读且更合理。 1、简单实例 <! </body> </html> --- 二、语法说明 1、运行规则 不同于传统的回调, then 关联的函数,会在异步操作完成后执行;如果有多个 then,那么也会依次调用,除非其中有调用 --- 2、创建 Promise 对象 通过 new 来创建 Promise 对象,当异步操作成功后调用 resolve 来改变 Promise对象的状态;失败后就调用 reject 。 const myFirstPromise = new Promise((resolve, reject) => { // 做一些异步操作,最终会调用下面两者之一: // // resolve await 只有用于异步函数才起作用,基于 promise 的函数之前加上 await ,代码会在此行暂停,直到 promise 操作完成,当然其他代码可以继续执行。

    1.7K51编辑于 2021-12-17
领券