草庐IT

sort_test

全部标签

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项目一样)?

c++ - GCC Address Sanitizer - 将库函数列入黑名单(特别是 boost::test)

我所有的单元测试代码都基于boost::test。我刚刚尝试了GCCAddresssanitizer,它报告了boost::test的一些问题:==25309==ERROR:AddressSanitizer:heap-use-after-freeonaddress0xf5801344atpc0x8259412bp0xff9966c8sp0xff9966bcREADofsize4at0xf5801344threadT0#00x8259411inboost::unit_test::framework::run(unsignedlong,bool)../common/lib/boost/bo

c++ - 网格 : "Sorting/Reordering" Arrays Referencing Shared Entries of Another for Cache Efficiency

给定一个顶点数组:{v1,v2,v3,v4,v5,...,vN}和K个多边形用这样的块索引它,用于示例4边多边形*:{v7,v2,v51,v16}请注意,两个或多个多边形可能共享同一个顶点。事实上,大多数顶点将由4-6个多边形共享(四边形网格的价数为4,三角形网格的价数为6)。...我们如何有效地重新排序/排序顶点数据,例如在读取给定多边形的顶点时减少缓存未命中?我对一种在合理时间内完成的算法感兴趣,而不仅仅是提供最佳结果的算法。在这里,即使是一些粗略的启发式方法也比完全任意的顺序要好。理想的情况是将{v1052,v507213,v63252,v3}之类的东西变成更像:{v70,v71

maven无法解决org.junit.test

我正在尝试通过命令行中的Groovy编译和运行单元测试。项目中的包装结构不遵循命名约定-这是我目前无法更改的。这些课程被组织为:src/abc/def/SomeClass.groovysrc/abc/tests/def/TestSomeClass.groovy当我跑步时mvntest,消息是:无法解析类org.junit.test和无法解析类org.junit.assert在课堂里src/abc/tests/def/TestSomeClass.groovy.我的pom是:4.0.0org.codehaus.mojomy-project1.0org.codehaus.gmavenplusgmav

c++ - Boost::Test——Main() 的生成?

我对设置boost测试库有点困惑。这是我的代码:#include"stdafx.h"#defineBOOST_TEST_DYN_LINK#defineBOOST_TEST_MODULEpevUnitTest#includeBOOST_AUTO_TEST_CASE(TesterTest){BOOST_CHECK(true);}我的编译器生成非常有用的错误消息:1>MSVCRTD.lib(wcrtexe.obj):errorLNK2019:unresolvedexternalsymbol_wmainreferencedinfunction___tmainCRTStartup1>C:\Use

c++ - 使用 std::sort 对二维数组进行排序(基于列)

我正在运行一个测试,显示按列对二维数组进行排序的好处,方法是将数据提取到一个单独的数组中并对该数组进行排序,然后将其复制回该列。我想运行std::sort作为每次运行的排序算法。我试图弄清楚如何先在适当的位置运行循环,然后再进入二维阵列的复制和复制。输入/输出的一个例子是这样的。#include#includeintmain(){intinput[][5]={{13,27,4,1,11},{11,19,2,37,1},{32,64,11,22,41},{71,13,27,-8,-2},{0,-9,11,99,13}};//std::sortsomethinghere.intoutput

c++ - boost::test 中是否有可以返回错误值的函数?

BoostTestLibrary是一个非常有用的单元测试框架。但是,我感到不舒服的一件事是,在单元测试期间,如果发生错误,它会通知用户而不是程序本身。让我以BOOST_CHECK为例来阐明我的观点:i=3;j=4;BOOST_CHECK(i==j);上面的测试用例会失败。因此,检查细节以找出此测试失败的原因将非常有趣。在这种情况下,如果程序知道单元测试失败,打印一些变量或执行更复杂的操作(例如将文件写入磁盘)将是必要的。但是,BOOST_CHECK不会返回一个值来表示测试是否成功。一个完美的函数应该是这样的:i=3;j=4;if(Enhanced_BOOST_CHECK(i==j)==

c++ - QuickSort 比 std::sort 慢

我有一个quick_sort代码(С++),看起来像这样templateBidirectionalIteratorquick_sort_partition(BidirectionalIteratorleft,BidirectionalIteratorright,Comparecmp){BidirectionalIteratorq=left-1;std::mt19937gen(time(0));std::uniform_int_distributionuid(0,right-left-1);intpivot_1=uid(gen);BidirectionalIteratorrandomNu

C++ std::sort 自定义函数

我有一个结构点:typedefstructPoint{doublex;doubley;Pointoperator-(constPoint&b){Pointpt;pt.x=this->x-b.x;pt.y=this->y-b.y;returnpt;}friendstd::ostream&operator>(std::istream&is,Point&pt){returnis>>pt.x>>pt.y;}}Point;我试图从vector中找到最小元素然后根据这个最小点的角度进行排序。下面是相应的代码:boollex_yx(constPoint&a,constPoint&b){if(a.yb