草庐IT

index-async

全部标签

c++ - 如何使用 yield_context 作为 resolver.async_resolve 的处理程序?

使用yield_context作为堆栈协程中Asio异步操作的处理程序非常棒!但是ip::basic_resolver::async_resolve的处理程序具有与简单地接收错误代码不同的签名(我很好奇为什么它不将resolver::iterator&作为async_resolve中的参数,就像basic_socket&中的basic_socket_acceptor::async_accept参数一样)).有没有办法使用yield作为它的处理者?同样的问题也适用于async_connect. 最佳答案 如StackfulCorout

c++ - io_service::run() async_* 函数的处理顺序

假设在调用io_service::run()时,有多个async_read操作被调度(它们之间可能还有其他操作)。当在ReadHandler函数中安排异步操作(如async_write)时会发生什么?voidhandler(constboost::system::error_code&error,std::size_tbytes){async_write(sock,boost::asio::buffer(wbuf),whandler);}也就是说,什么时候调用async_write?我希望执行顺序是:1)async_read//12)async_write3)async_read//2

c++ - std::type_index 跨 DLL 是否安全

假设我有一个主DLL,其中有一个这样的类:classTest{public:typedefstd::unordered_mapMap;templatevoidSetValue(intval){SetValue(std::type_index(typeid(T)),val);}templateintGetValue(){returnGetValue(std::type_index(typeid(T)));}protected://Definedin.cppfilevoidSetValue(conststd::type_index&idx,intval){m_Map[idx]=val;}/

c++ - std::async 和 std::future 行为

我试图理解异步行为并编写了一些愚蠢的测试程序。intf(inti){std::cout使用上面的代码,输出似乎是完全同步的。所有10000个线程似乎都按顺序执行。主线程block。0:hello1:hello2:hello.......10000:helloinmain但是,当返回的future存储在vector中时,输出全部被破坏并且main退出而不等待生成的线程。线程是否在此处分离?intmain(){std::vector>v;for(inti=0;i输出:2:hello3:hello46:hello:hello5:hello9:hello10:hello11:hello最后,尝

c++ - 从 sdl 调色板表面创建 OpenGL 纹理 (SDL_PIXELFORMAT_INDEX8)

我创建了一个bmp并使用SDL_LoadBMP加载它检查生成的SDL_Surface时,我可以看到它的格式为SDL_PIXELFORMAT_INDEX8。我想使用SDL表面使用glTexImage2D生成纹理.通常我只能检查表面接近于此的东西:SDL_Surface*surface=SDL_LoadBMP(filename.c_str());GLenummode=0;Uint8bpp=surface->format->BytesPerPixel;Uint32rm=surface->format->Rmask;if(bpp==3&&rm==0x000000ff)mode=GL_RGB;i

c++ - 如何在 Boost multi_index 复合键中删除?

我正在检查这个Boostmulti_indexcompositekeysusingMEM_FUN谁能告诉我如何为这个例子实现删除功能?现在我在做Name_set_by_last::iteratormitchells=names.get().find("mitchell");names.erase(mitchells);//showserror 最佳答案 names.get().erase(mitchells); 关于c++-如何在Boostmulti_index复合键中删除?,我们在St

c++ - boost::asio::async_read_until 问题

我正在尝试修改来自boostasio的echo服务器示例,当我尝试使用boost::asio::async_read_until时遇到了问题。这是代码:#include#include#include#includeusingboost::asio::ip::tcp;classsession{public:session(boost::asio::io_service&io_service):socket_(io_service){}tcp::socket&socket(){returnsocket_;}voidstart(){std::coutsocket(),boost::bind

c++ - 由于超时取消async_read

我正在尝试围绕async_read编写一个包装器同步方法,以允许在套接字上进行非阻塞读取。根据互联网上的几个例子,我开发了一个似乎几乎正确但不起作用的解决方案。该类声明了这些相关的属性和方法:classcommunications_client{protected:boost::shared_ptr_io_service;boost::shared_ptr_socket;boost::array_data;boost::mutex_mutex;bool_timeout_triggered;bool_message_received;boost::system::error_code_e

c++ - std::async "store"如何成为任意异常?

我无法理解std::async怎么可能存储任何异常,而不仅仅是从std::exception派生的东西。我玩弄了下面的代码#include#include#includevoidf(){std::coutfut=std::async(std::launch::async,f);std::cout我异步启动f(),然后在f中抛出一个int。神奇的是,这个int被std::async返回的future捕获并存储。我知道可以在std::async中catch(...)异常,但后者如何在不知道异常类型的情况下存储它?异常不是从某个基类派生的(在这种情况下,可能可以通过一些Base::clone

c++ - "no matching function for call to ‘async(std::launch, <unresolved overloaded function type>, std::string&)’“

我正在尝试使用std::async创建线程,但我不断收到错误“没有匹配函数调用‘async(std::launch,,std::string&)’”在行上ConnectFuture=std::async(std::launch::async,Connect_T,ip);这是产生这种行为的代码:#includeclasslibWrapper{public:voidConnect(std::stringip);voidConnect_T(std::stringip);private:std::futureConnectFuture;};voidlibWrapper::Connect(std