草庐IT

BOOST_STATIC_ASSERT

全部标签

c++ - 使用整数索引访问 boost::graph 中的特定边

这与我昨天关于使用整数索引访问顶点的问题有关。该线程在这里:Accessingspecificverticesinboost::graph那里的解决方案表明,使用vecS作为顶点类型,确实可以使用整数索引访问特定顶点。我想知道boost是否提供了类似的方法来使用整数索引有效地访问任意边缘。附件是描述前者(有效访问具有整数索引的顶点)和基于开发人员显式维护两个数组访问边的代码,from[]和to[],分别存储边的源和目标。代码创建了下图:#include#include#include#include#includeusingnamespaceboost;typedefadjacency

c++ - 是否有任何理由不将 assert() 包装在解析为 gcc 中的 __builtin_unreachable() 的宏中?

上下文:在这个answer,我了解到gcc的__builtin_unreachable()可能会对性能产生一些令人惊讶的影响,因为看起来如下:if(condition)__builtin_unreachable();被完全剥离,用作优化提示,只要condition可以保证没有任何副作用。所以我对此的直接react是我应该创建以下宏,并且绝对在我通常使用assert()的所有地方使用它,因为在assert中会产生副作用()首先会是一个主要错误://TODO:addhandlingofothercompilersasappropriate.#ifdefined(__GNUC__)&&def

c++ - CMake Find_Package(PythonLibs): Does CMake give a preference to dynamic or static libraries?

当我运行FindPackage(PythonLibs)时,它首先找到静态python库python3.5m.a,而不是python3.5m.so。这是CMake的预期行为吗?我怀疑它不符合CMakebugreport;然而,这个错误报告是在2005年提交的。13年来情况发生了变化。如果共享库有偏好,那么知道为什么CMake会找到静态库而不是共享库吗?我已经通过使用SET()命令告诉CMake正确的库在哪里用于我自己的构建来解决构建问题。我正在寻找一个可以更好地理解CMake在这种情况下的行为的答案,因为我正在尝试解决不同的problem,并在共享库中找到static对我来说似乎很奇怪。

c++ - 为什么异常不适用于 OSX 上的 gcc7 和 -static-libgcc?

如果我用gcc-7、-static-libstdc++和-static-libgcc编译这个简单的程序;然后在OSX上运行#include#includeintmain()try{throwstd::runtime_error{"abc123"};return0;}catch(conststd::runtime_error&e){std::cout失败,错误代码为134。为什么它不像在linux上使用相同选项编译时那样打印“abc123”? 最佳答案 已在GCC8中修复(-ish);查看对PR86215的更新和相关的PR80556.

python - 链接 boost::python::numpy 时出现问题

我写了一个小例子来说明发生了什么。我的测试.cpp#include#includenamespacenp=boost::python::numpy;intmy_Foo(){Py_Initialize();np::initialize();std::coutpy_test.pyimportmy_testastt.my_Foo();我用命令编译所有:g++-shared-fPIC-omy_test.somy_test.cpp-lboost_python-lpython2.7-I/usr/include/python2.7我得到这个错误:ImportError:/home/my_test.s

c++ - Visual Studio(或任何其他工具)能否将地址解释为调用堆栈的开始( boost 上下文)?

是否可以告诉VisualStudio(或任何其他主要操作系统上的任何其他工具)将地址解释为调用堆栈的开头?我想要实现的目标:我们有一个库,它使用boost的make_fcontext/jump_fcontext并将这些上下文存储到一个容器,以便暂停一些调用以供以后处理。我的问题是-是否有可能以某种方式调试这些挂起的调用是什么?我想,我可以告诉调试器/工具类似:“这是这个地址,虽然它并不明显,但它实际上指向一个调用堆栈,‘解析’它并像标准调用堆栈一样显示给我”。不知道这在理论上是否可行,因为我不知道boost::context的细节,但它听起来是可以实现的。有没有人尝试过处理这个问题?

c++ - CMake 可以找到一个 Boost 头文件,但找不到另一个

由于Boost库可以单独安装在某些系统上(即使这种情况可能很少见),我想确保它们可用。我通过检查一些我需要的头文件来做到这一点:check_include_file_cxx(boost/parameter/keyword.hppHAVE_BOOST_PARAMETER_KEYWORD_HPP)check_include_file_cxx(boost/asio/io_service.hppHAVE_BOOST_ASIO_IO_SERVICE_HPP)我遇到的问题是CMake声称它可以找到boost/parameter/keyword.hpp头文件,但找不到boost/asio/io_se

c++14 static constexpr auto 与 odr 用法

我有以下C++14代码:templatestructTest{staticconstexprautosomething{T::foo()};};这很好,只要T::foo()也是一个constexpr。现在我知道something是ODR使用的,所以我需要提供命名空间声明。我应该使用什么语法?templateconstexprautoTest::something;不起作用。谢谢! 最佳答案 通过using定义的类型名怎么样?templatestructTest{usingsomeType=decltype(T::foo());sta

c++ - Boost::Beast:带有 websocket 流水线的服务器

我正在编写一个带有boostbeast1.70和mysql8C连接器的c++websocket服务器。服务器将同时连接多个客户端。特殊之处在于每个客户端将向服务器连续执行100个websocket请求。我的服务器的每个请求都是“CPU轻型”,但服务器对每个请求执行“时间繁重”的SQL请求。我已经使用websocket_server_coro.cpp示例启动了我的服务器。服务器步骤是:1)websocket读取2)一个sql请求3)websocket写入问题是对于给定的用户,服务器在第2步被“锁定”,并且在这一步和第3步完成之前无法读取。因此,这100个请求是按顺序解决的。这对我的用例来

c++ - 转换宽字符串以 boost 日期

我需要将数百万个存储为宽字符串的日期转换为boost日期以下代码有效。但是,它会生成一个可怕的编译器警告并且看起来效率不高。有没有更好的办法?#include"boost/date_time/gregorian/gregorian.hpp"usingnamespaceboost::gregorian;#includeusingnamespacestd;wstringws(L"2008/01/01");stringtemp(ws.length(),'\0');copy(ws.begin(),ws.end(),temp.begin());dated1(from_simple_string(