草庐IT

hit-boosted

全部标签

c++ - 使用 Boost Asio 从串行端口读取

我想使用boost.asio检查串行端口上的传入数据包。每个数据包都以一个字节长的报头开头,并指定所发送消息的类型。每种不同类型的消息都有自己的长度。我要编写的函数应该不断地监听新传入的消息,当它找到一个消息时应该读取它,并调用其他函数来解析它。我目前的代码如下:voidcheck_for_incoming_messages(){boost::asio::streambufresponse;boost::system::error_codeerror;std::strings1,s2;if(boost::asio::read(port,response,boost::asio::tra

c++ - 使用指定 ip 和端口的 boost asio 创建 iostream

我有一个关于boostasio库的问题。我成功地尝试在客户端和服务器之间创建套接字,这涉及创建解析器以指定服务器的ip和端口(服务器只需要端口)和其他对象,但最重要的是,有必要使用write和read_some作为从/在套接字中读取和写入的函数。我真的很感激使用流,这在boostasio中是可能的,但这很奇怪......在几乎所有使用流的示例中,要创建服务器就必须提供端口,好吧,让我们谈谈客户端...客户端,需要使用iostream构造函数指定用于连接流的坐标,这是代码:tcp::iostream()s(argv[1],"daytime");好吧,我真的不明白第一个参数传递的是什么,也

c++ - Boost.Program_options 没有参数默认行为?

我正在使用Boost::Program_options来解析我的命令行,并改编了教程中的一些代码,如下所示:try{po::options_descriptiondesc("Allowedoptions");desc.add_options()("help,h","outputhelpmessage")("width,w",po::value()->required(),"width");po::positional_options_descriptionp;p.add("width",1);po::variables_mapvm;po::store(po::command_line_

c++ - boost 是否有可移植的方式来使用 ntohl/htonl/ntohs/htons 类型的函数?

如果有帮助,我正在使用UDP,尤其是boost::asio::ip::udp::socket套接字?什么是头文件?我需要哪些header/类来处理boost下UDP的网络字节排序? 最佳答案 刚刚发现足够#include因为这会拉入所有依赖于平台的header并提供对htonl/ntohl的访问权限这正是我所需要的。感谢大家的建议。 关于c++-boost是否有可移植的方式来使用ntohl/htonl/ntohs/htons类型的函数?,我们在StackOverflow上找到一个类似的问

c++ - boost::smart_ptr 可以用在 std 容器中吗?

scoped_ptr、shared_ptr等boost::smart_ptr可以用在std::map等std容器中吗?classSomeClass{std::map>a_map;};作为boost::smart_ptrcanbeusedforpolymorphism,在这种情况下也是如此吗?容器的销毁会触发子类的正确销毁吗? 最佳答案 scoped_ptr不能在标准容器中使用,因为它不能被复制(这是容器接口(interface)所要求的)。但是,可以使用shared_ptr。如果您不能使用C++11而您已经在使用boost,请考虑p

c++ - C++ boost 绑定(bind)性能

绑定(bind)函数(使用BoostBind)时是否有任何性能影响(正面或负面)? 最佳答案 也许,也许不是。这取决于。std::bind(或boost::bind)的结果是所谓的“绑定(bind)表达式”,它具有由执行。此类型是一个Callable,并且它可转换为std::function(或boost::function).在内部,函数(可能)使用类型删除来处理各种复杂的、有状态的“可调用对象”。在某些(但不一定是所有)情况下,这需要动态分配和虚拟调度。bind和function都是有状态的,因为它们存储绑定(bind)参数。结

c++ - 理解 Boost.Spirit 中的列表运算符(%)

你能帮我理解a%b解析器和它在Boost.Spirit中扩展的a>>*(b>>a)形式之间的区别吗?尽管thereferencemanual声明它们是等价的,Thelistoperator,a%b,isabinaryoperatorthatmatchesalistofoneormorerepetitionsofaseparatedbyoccurrencesofb.Thisisequivalenttoa>>*(b>>a).以下程序根据使用的不同产生不同的结果:#include#include#include#include#includestructRecord{intid;std::v

c++ - boost 备忘单

关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于StackOverflow来说是偏离主题的,因为它们往往会吸引自以为是的答案和垃圾邮件。相反,describetheproblem以及迄今为止为解决该问题所做的工作。关闭9年前。Improvethisquestion我刚刚有一个在C++上进行简单操作的项目,然后当我几乎完全完成该项目时,我发现所有这些愚蠢的任务只需要一部分boost。这非常令人沮丧,让我想知道有多少这些烦人的问题可以通过boost库的一个功能来解决。所以问题是,boost库是否有备

java - 我可以使用 C++ Boost shared_ptr 进行编程,就好像我在用 Java 编写代码一样,而不关心内存管理吗?

我用C/C++编写代码已经有一段时间了,现在我正在做的项目需要它的效率。我从这个shared_ptr中了解到,它基本上是在我需要时删除对象。因此,例如,如果我的对象有一个shared_ptrvector,我就不必担心遍历vector并删除析构函数中的每个元素了吗?也就是说,我只要用这些就不用担心内存管理了?还是我完全误解了这一点?听起来好得令人难以置信。 最佳答案 你必须明白共享指针是使用引用计数实现的,这意味着如果你的指针图中有循环,那么对象将不会被释放。也就是说,如果a指向b,b指向a,但没有任何东西指向a或b,那么a和b都不会

c++ - 我可以从 boost 的 weak_ptr 获得原始指针吗?

是否可以从boost::weak_ptr获取原始指针?Boost的shared_ptr有get()方法和“->”运算符。weak_ptr不具有相同功能背后有什么理由吗? 最佳答案 weak_ptr拥有一个非拥有引用,因此它所引用的对象可能不再存在。使用weak_ptr持有的原始指针本质上是危险的。正确的方法是使用weak_ptr::lock()将weak_ptrboost为shared_ptr并从中获取指针。Boostweak_ptrdocumentation解释了为什么将get()功能作为weak_ptr的一部分提供是不安全的,并