草庐IT

promised-mongo

全部标签

HarmonyOS 通过Promise 解决异步回调地狱问题

上文HarmonyOS发送http网络请求我们讲了在harmonyos中发起http网络请求的方法但是我们异步请求也讲过回调地狱的问题如果您还不知道什么叫回调地狱可以查看我的文章异步回调地狱Promiseasyncawait这是我们上文留下的代码importhttpfrom'@ohos.net.http'@Entry@ComponentstructIndex{aboutToAppear(){lethttpReq=http.createHttp();httpReq.request("http://localhost/books",{method:http.RequestMethod.GET},(

c++ - 从模板 Callable 生成 promise

我正在尝试从接受Callable类型的模板函数创建一个promise。但我不确定该怎么做。我尝试使用std::invoke_result_t,但这需要参数来知道结果类型,而我在构建promise时不知道这些。有什么方法可以推断返回类型?我想在通用lambda的情况下这可能是不可能的,但是在非通用lambda情况下有什么用吗?templateclassJob{public:Job(Callable&&c,Promise&&p):callable(std::move(c)),promise(std::move(p)){}autogetFuture(){return/*astd::share

C++11 std::promise 从线程返回 std::string,数据指针看起来已复制未移动

我开始使用C++11标准和内置线程。根据我在获得future值时收集到的信息,它是使用移动运算符完成的,将所有权从原始对象中移走(就像旧的auto_ptr曾经在赋值时所做的那样)。我通过在线程期间打印出std::string对象内的char数组的指针并在main中接收到它后打印指针来测试这一点。但是,指针不同。如果有人能告诉我为什么他们在这个简单的代码中不同以及代码必须是什么样子才能使它们相等,我将不胜感激:#include#include#include#include#include#include#include#includeusingnamespacestd;voidthrf

docker环境下mongo副本集的部署及异常修复

最近更换了办公地点。部署在本地docker环境里的mongo数据库不能使用了。原因是本地的ip地址变更。以前的mongo副本集的配置需要更新。处理完后,索性重新记录一下mongo副本集在docker中的部署流程。mongo的事务及副本集我们先了解一下什么是事务,事务是一组对数据库执行的操作,这些操作作为一个不可分割的工作单元。在MongoDB中,一个事务可以涉及多个文档和多个集合。例如一个订单的下单过程,涉及到订单的生成,商品库存变化等多个文档的变化。在服务端执行过程中,如果某一段代码产生了错误。不使用事务的话,可能会导致订单生成来,商品库存却不变的情况发生。而使用事务后,整个下单将会作为一个

C++ 什么是 std::shared_future 和 std::promise

我了解什么是std::future但我不了解何时以及如何使用std::shared_future和std::promise,而且我在网上找不到很好的解释。我会很感激一些帮助我解决这个问题。顺便说一句,这里的例子不是很清楚http://en.cppreference.com/w/cpp/thread/shared_future 最佳答案 std::shared_future当您需要拥有std::future的多个有效拷贝时,并且可能是上述std::future的多个消费者.您可以移动std::future进入std::shared_f

一文搞懂 Promise 新 Api allSettled 的用法和 all 区别,以及如何在不支持新特性的环境下实现一个 Polyfill

开始一文搞懂Promise新ApiallSettled的用法和all区别,以及如何在不支持新特性的环境下实现一个PolyfillallSettled的用法construnAllSettled=async()=>{constsuccessPromise=Promise.resolve('success')//一个正常返回的PromiseconstfailPromise=Promise.reject('fail')//一个异常返回的Promise//使用allSettledconstsettiled=awaitPromise.allSettled([successPromise,failPromi

12.使用Promise封装Ajax

步骤都差不多,只是新创建了一个Promise对象,成功时调用resolve函数,失败时调用reject函数,然后再将这个promise返回出去functionajax(options){letpromise=newPromise(function(resolve,reject){//创建xhr对象constxhr=newXMLHttpRequest();//初始化参数的内容options=options||{};options.type=(options.type||'GET').toUpperCase();options.dataType=options.dataType||'json';/

GCC 中的 C++11 thread_pool、futures、promises 支持

是N2276中的任何一个gcc支持吗?我目前使用的是4.6.1,其中std::thread似乎工作正常。如果不是,我应该使用boost'sthreadpool?什么是可以轻松过渡到最终futures、promises和thread_pool的良好替代方案/权宜之计?也许this有用吗?N2276似乎没有列出here.我想知道N2276的任何特性是否会被纳入-我想我读到了有关futures和promises以及其他进入C++11的范例:将不得不谷歌看看周围发生了什么。 最佳答案 gccC++librarystatuspage显示其中大

c++ - std::promise<T> 是线程安全的吗?

它安全吗,就像std::mutex的情况一样对于std::promise待制mutable,还是取决于T?如:usingData=std::tuple;structX{std::futureprepare()const{returnm_promise.get_future();}voidasyncHandler(inta,intb)const{m_promise.set_value({true,a,b});}voidcancel()const{m_promise.set_value({false,0,0});}mutablestd::promisem_promise;//Isthiss

c++ - std::promise 可以从非 POD 对象生成吗?

我的应用程序所做的其中一件事是监听和接收来自套接字的有效负载。我从不想阻止。在收到的每个有效负载上,我想创建一个对象并将其传递给工作线程,直到稍后再忘记它,这就是原型(prototype)代码的工作方式。但是对于生产代码,我想通过使用方便的异步方法来降低复杂性(我的应用程序很大)。async从promise中获取future。为此,我需要在下面由Xxx类表示的非POD对象上创建一个promise。我看不到有任何方法可以做到这一点(请参阅下面我的示例代码中的错误)。这里用async合适吗?如果是这样,我如何构建一个比int更复杂的promise/future对象(我看到的所有代码示例都使