草庐IT

c++ - 我们可以创建一个已经打开的套接字的 boost 套接字吗?

我有一个代码,通过一个stunServer为我的对等软件创建一个套接字,我想知道是否有可能创建一个boost::udp::socket已经打开的套接字?我已经在boost文档中进行了搜索,但没有找到允许这样做的内容。 最佳答案 是的。io_serviceios;ip::udp::socketsocket(ios);intnative_socket=::socket(AF_INET,SOCK_DGRAM,IPPROTO_UDP);socket1.assign(ip::udp::v4(),native_socket);参见thissam

c++ - 我如何在 void* 和 boost shared_ptr 之间进行转换

我有这些行:typedefboost::shared_ptrA_SPtr;void*f(void*var){...我希望能够做这样的事情:A_SPtrinstance=(void*)(var);我该怎么做?另外,我怎样才能将意义从shared_ptr转换为void*? 最佳答案 只需将指针转换为指向和来自void*的共享指针。shared_ptr到void*:f(reinterpret_cast;(&A_SPtr));void*回到shared_ptr:A_SPtrinstance=*reinterpret_cast(boost::

c++ - condition_variable_any 与 recursive_mutex 一起使用时的行为?

当condition_variable_any与recursive_mutex一起使用时,recursive_mutex是否通常可从其他线程获取,同时condition_variable_any::wait正在等待?我对Boost和C++11实现都很感兴趣。这是我主要关心的用例:voidbar();boost::recursive_mutexmutex;boost::condition_variable_anycondvar;voidfoo(){boost::lock_guardlock(mutex);//Ownershiplevelisnowonebar();}voidbar(){b

c++ - 是否有用于阻塞 boost::asio TCP 连接的 boost::iostreams(双向)设备?

我正在研究可移植的C++库,阻止对文件系统和网络的I/O访问。看起来boost::filesystem、boost::iostreams和boost::asio将介于这三者之间他们的工作。明确地说,我目前对boost::asio的异步方面不感兴趣;我只想要一个可移植的阻塞式网络接口(interface)。深入研究,我看到boost::iostreams有一个设备的概念,每个设备都有一个关联的modeconcept.双向模式似乎专门为流式访问全双工TCP连接而量身定制。太棒了。boost::iostreams似乎不支持实际打开TCP连接(与本地文件系统不同。)没关系,boost::asi

c++ - 将 std::map 复制/插入到 boost::bimap

我尝试将std::map的元素复制到boost::bimap中。我无法让std::copy工作(boost文档似乎表明bimap应该与std::copy兼容)。我尝试了以下方法:std::mapcurves;boost::bimap,boost::bimaps::multiset_of>m_curves;...//someinitialisationofcurvesstd::copy(curves.begin(),curves.end(),std::inserter(m_curves,m_curves.end()));//Thisfailsm_curves.insert(curves.

c++ - 为什么此代码会导致访问冲突?

这个函数工作得很好,或者编译器/调试器告诉我voidGUIManager::init(ToScreen*tS){toScreen=tS;loadFonts();GUI_Surface=SDL_SetVideoMode(toScreen->width,toScreen->height,32,SDL_SWSURFACE);components.push_back(&PlainText("Hello,World!",font,-20,-40));}在这里,第一个函数调用引发了访问冲突错误。调试器没有显示任何问题。我没有机会调试组件[0],因为程序在此处停止。voidGUIManager::d

c++ - 指向不同返回类型和签名的函数的指针映射

我正在寻找一种通过字符串输入调用不同函数的方法。我有一个映射,将每个唯一字符串绑定(bind)到一个函数指针和一个查找函数,用于搜索映射并在找到时返回一个指针。现在的诀窍是,我需要一种方法来存储和返回指向至少具有不同返回类型的函数的指针,如果可能的话,还具有不同的签名。用法是:从网络套接字获取字符串输入->查找并执行找到的函数->将结果直接推回套接字以进行序列化和发送,而不关心实际发生了什么。这可行吗?如果没有,人们将如何处理这项任务? 最佳答案 这可以通过一些不同方式的样板代码来完成。如果签名的数量足够少,您可以保存多个函数指针v

c++ - 使用 boost::posix_time::microsec_clock 的测量误差超过十微秒?

我有以下代码:longlongunsignedintGetCurrentTimestamp(){LARGE_INTEGERres;QueryPerformanceCounter(&res);returnres.QuadPart;}longlongunsignedintinitalizeFrequency(){LARGE_INTEGERres;QueryPerformanceFrequency(&res);returnres.QuadPart;}//starttimestampboost::posix_time::ptimestartTime=boost::posix_time::mic

c++ - 如何识别boost fusion vector 中的类型

如何识别boost::fusionvector中的类型?例如fusion::vectorv;然后可以让我将v[0]识别为int类型,将v[1]识别为double类型和v[2]作为string类型。谢谢。 最佳答案 为了从boost::fusion::vector中提取元素,您需要使用boost::fusion::at_c,如下所示:boost::fusion::vectorv(1,"hello");std::cout(v)N位置的类型是:boost::fusion::result_of::at_c,1>::type

c++ - boost std unique_ptr 的 STL 集合的序列化

我希望能够序列化std::unique_ptr的STL容器。可以吗?顺便说一句,单个std::unique_ptr一切正常。下面是我正在处理的代码,gcc给出了以下错误:useofdeletedfunction‘std::unique_ptr::unique_ptr(conststd::unique_ptr&)[with_Tp=MyDegrees;_Dp=std::default_delete;std::unique_ptr=std::unique_ptr]’如何使代码正常工作?#include#include#include#include#include#include#inclu