草庐IT

package_test

全部标签

c++ - 在 CMake 中处理多个 FIND_PACKAGE 调用

我有一个关于CMake中的FIND_PACKAGE函数的快速问题。我有一个利用点云库(PCL)的项目。PCL依赖于Boost,我的项目也是如此。因此,在我的CMakeLists.txt顶部,我有以下内容:FIND_PACKAGE(BoostREQUIREDCOMPONENTSprogram_options)#PreserveprojectBoostrequiredlibrariesSET(Boost_PROJECT_LIBRARIES${Boost_LIBRARIES})FIND_PACKAGE(PCL1.6REQUIREDCOMPONENTScommonsearch)我的项目使用了B

c++ - 加速 RcppArmadillo : How to link to OpenBlas in an R package

我正在开发一个使用RcppArmadillo的R包。我正在尝试利用OpenBLAS中更快的矩阵乘法。在documentation在C++armadillo库中,它说如果我们的机器上有OpenBLAS,那么Armadillo将使用OpenBLAS而不是BLAS。然而,当我编译我的R包时,我得到如下信息:g++-m64-std=c++11-shared-L/usr/lib64/R/lib-Wl,-z,relro-specs=/usr/lib/rpm/redhat/redhat-hardened-ld-oPackageTest.soclass1.oclass2.oclass3.oclass4

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对我来说似乎很奇怪。

cmake - CMakeLists.txt中应该在哪里调用find_package?

在cmake项目中包含外部库通常使用find_package()执行。但是在一个大型的多应用程序/多库项目中,一些第3方和/或系统库被多个应用程序和库使用是很典型的。这些常用库的find_package()应该在哪里调用?在每个需要它们的可执行文件/库的CMakeLists.txt文件中?或者,在顶级CMakeLists.txt文件中?第一个选项似乎是一种更加模块化的方法,但相关的find_package()脚本是为使用它们的每个库/可执行文件执行的。这会减慢配置步骤。第二个选项更有效,但对我来说看起来有点像全局变量。 最佳答案 我

c++ - 标准保证在移动 std::packaged_task 后安全使用 std::future 吗?

假设我们有以下代码:#include#includeintmain(){autopackagedTask=std::packaged_task([]{std::cout(std::move(packagedTask));autov1=packagedTaskFuture.valid();//isvalidautov2=packagedTaskFuture.wait_for(std::chrono::seconds(0));//timeoutstate(*packagedTaskPtr)();//executetaskautov3=packagedTaskFuture.wait_for(

c++ - test_and_set 线程的这种用法安全吗?

一直在思考如何实现无锁单向链表。老实说,我没有看到很多防弹方法。即使是使用CAS的更强大的方法最终也会有一定程度的ABAproblem.所以我开始思考。部分无锁系统难道不会比总是使用锁更好吗?一些操作可以是原子的和无锁的吗?如果我能做到这一点,它应该仍然是线程安全的。那么,进入正题。我在想一个简单的单向链表。2主要操作。push和pop。push总是在前面插入。像这样:voidpush(intn){T*p=newT;p->n=n;p->next=root;root=p;}pop总是取第一个元素。像这样:T*pop(){T*p=root;root=root->next;returnp;}

c++ - 何时在 Boost Test 库中使用手动注册?

我一直使用BoostTest的自动注册。现在我想知道,手动注册有什么用?是否存在自动注册无法处理的情况?补充说明,这次我也将使用turtle进行模拟。编辑:似乎我的问题不清楚,更准确地说:我什么时候应该使用手动注册而不是自动注册?我为什么要这样做?自动注册不足以解决哪些现实生活情况? 最佳答案 根据documentationToalleviatethisissuetheUTFpresentsfacilitiesforautomated(inplace)testcasecreationandregistrationinthetestt

c++ - 如何使用模板函数作为 Boost::Unit-test 的自定义谓词

我正在尝试为BOOST_CHECK_PREDICATE构建自定义谓词,其中谓词本身是一个模板函数。我的示例如下所示:#defineBOOST_TEST_MODULEModule#defineBOOST_TEST_MAIN#include//custompredicatetemplateboolis_close_enough(constU&a,constV&b){returnstd::abs(a-b)使用MSVisualC++2010编译会出现以下错误:3>..\boost_test\testSystem.cpp(42):errorC2780:'boolboost::test_tools

c++ - 测试 C++ 代码 : Using test libraries

我学习C++有一段时间了,但这是我第一次接触C++项目(宠物配置解析器库)。我正在使用GoogleC++TestingFramework来测试这个。但我不知道我这样做是否正确。目前,我已经剥离了这个Google测试库的一些部分并将其放入我的项目Test/googletest目录中。它工作正常,但我想知道我是否应该这样做。我在我的项目中包含了测试框架的源代码,它将与我的代码一起发布。这让我感到不舒服。我浏览了someC++projectsonGitHub,试图看看其他人如何处理这个问题。有些有自定义框架,大多数根本不测试代码就解决了整个问题。我想知道我是否做对了,或者我怎样才能采用一种测

c++ - 如何通过命令行运行 Google Test?

我有一个启动并运行GoogleTest的示例项目。我有一个简单的测试类,如下所示:#includeTEST(FirstTest,TestNumberOne){EXPECT_NE(2,1);}这是在我电脑上的目录/home/dave/Desktop/sandbox/black-test/src/code/Tester.cpp我在使用Ubuntu的Eclipse中工作。测试类在Eclipse中运行良好(右键单击,以C++运行)。但是我找不到关于如何通过命令提示符运行的文档?其次,大多数为C++进行单元测试的人是将他们的测试项目与生产代码分开还是耦合(就像大多数Java项目一样)?