草庐IT

target-async

全部标签

c++ - boost asio udp 套接字 async_receive_from 不调用处理程序

我想创建一个自治线程,专门用于使用boost库(asio)从UDP套接字接收数据。这个线程应该是一个无限循环,由从UDP套接字接收到的一些数据触发。在我的应用程序中,我需要使用异步接收操作。如果我使用同步函数receive_from,一切都会按预期工作。但是,如果我使用async_receive_from,则永远不会调用处理程序。由于我使用信号量来检测是否已接收到某些数据,因此程序锁定并且永远不会触发循环。我已经(使用网络分析器)验证发送方设备在UDP套接字上正确发送数据。我已在以下代码中找出问题。#include#include#include#include#includetype

c++ - boost::asio:如何使用 async_accept 接受传入连接?

我正在使用boost::asio,我有这样的代码:voidCServer::Start(intport){tcp::acceptoracceptor(m_IoService,tcp::endpoint(tcp::v4(),port));for(;;){shared_ptrpSocket(newtcp::socket(m_IoService));acceptor.accept(*pSocket);HandleRequest(pSocket);}}此代码有效,但我想切换到使用Acceptor::async_accept以便我可以调用Acceptor::cancel来停止接收请求。所以我的新

c++ - boost .asio : can I do async_read and async_write simultaneously from one thread?

我读到不建议对来自不同线程的套接字进行多项操作。但是,如果我从同一个线程socket.async_read和下一个socket.async_write调用(不等待前一个完成)怎么办?当其中一个操作完成时,我可以期望正确的回调会运行吗? 最佳答案 我发现是的,您可以在同一个套接字上有一个挂起的async_read和一个挂起的async_write而不会出现问题。当您调用io_service::run()方法时,回调将按预期完成。在同一个套接字上发出多个async_reads,或在同一个套接字上发出多个async_writes,可能会导

c++ - CMake 错误 : CMake can not determine linker language for target: myapp

我正在尝试通过cmake编译vMime,但出现上述错误,我正在使用cmake的图形界面,我的makefiles.txt在下面。它配置正确但不生成cmake_minimum_required(VERSION2.8)PROJECT(CXX)#vmimeenable_language(CXX)set(VerifyCXXVerifyCXX.cxx)add_definitions(-DVERIFY_CXX)set_target_properties(${TARGET}PROPERTIESLINKER_LANGUAGECxx)add_executable(myappvmime)install(TA

c++ - 在 CMake 中,指定所有可执行文件 target_link_libraries 某些库

在CMake中,有没有办法指定我所有的可执行文件都链接到某个库?基本上我希望我所有的可执行文件都链接到tcmalloc和分析器。简单地指定-ltcmalloc和-lprofiler不是一个好的解决方案,因为我想让CMake以可移植的方式找到库的路径。 最佳答案 您可以使用您自己的函数覆盖内置的add_executable函数,它总是添加所需的链接依赖项:macro(add_executable_name)#invokebuilt-inadd_executable_add_executable(${ARGV})if(TARGET${_

c++ - "No rule to make target ' 安装 '"... 但是 Makefile 存在

我在安装C++库时遇到问题。CMake命令成功并生成Makefile,但它给出警告:CMakeWarning(dev)atCMakeLists.txt:27(LINK_DIRECTORIES):Thiscommandspecifiestherelativepath../usr/local/libasalinkdirectory.PolicyCMP0015isnotset:link_directories()treatspathsrelativetothesourcedir.Run"cmake--help-policyCMP0015"forpolicydetails.Usethecmak

c++ - std::async 不能异步工作

我有以下非常简单的代码:voidTestSleep(){std::cout因为我使用std::launch::async我希望TestSleep()将异步运行并且我将得到以下输出:TestAsyncTestAsyncok!!!TestSleepTestSleepOk但实际上我有同步运行的输出:TestAsyncTestSleepTestSleepOkTestAsyncok!!!您能解释一下为什么以及如何使TestSleep真正异步调用吗。 最佳答案 来自thisstd::asyncreferencenotessectionIfthe

c++ - MSBuild:VS2010 中 native C++ 项目的 Custom.After.Microsoft.Common.targets

我读过“Custom.Before.Microsoft.Common.targets”和“Custom.After.Microsoft.Common.targets”的使用,以便在每个项目构建之前/之后执行自定义目标,我会喜欢在我们的TeamCity构建服务器上构建时使用此技术来更改版本信息。问题是,虽然它适用于C#项目,但它似乎不适用于nativeC++项目。在深入研究Microsoft.Cpp.targets文件后,我发现对于nativeC++项目,这似乎是通过设置$(ForceImportBeforeCppTargets)和$(ForceImportAfterCppTargets

c++ - 将 std::async 与模板函数一起使用

我如何,或者,我可以将模板函数传递给async?代码如下://main.cpp#include#include#include#includeintmain(){std::vectorv(16,1);autor0=std::async(std::launch::async,std::accumulate,v.begin(),v.end(),double(0.0));std::cout错误信息如下:^a.cpp:13:88:note:candidatesare:Infileincludedfroma.cpp:1:0:/usr/include/c++/4.8/future:1523:5:n

c++ - async([](){}) 和 thread([](){}).detach() 有什么区别?

下面两个语句在执行方面有什么区别?async([](){...});thread([](){...}).detach(); 最佳答案 std::async([](){...});//(1)std::thread([](){...}).detach();//(2)大多数情况下,当std::async被讨论时,首先注意到的是它被破坏了,这个名字暗示了当返回值不被接受时不成立的东西(分配给要在当前作用域结束时销毁的变量)。在这种情况下,std::async的中断正是导致(1)和(2);一个会阻止,另一个不会。为什么std::async会在