草庐IT

pause_test_threads

全部标签

c++ - Visual Studio C++ : Unit test exe project with google test?

使用VisualStudio2010C++。我正在尝试单元测试并决定尝试GoogleTest(gtest)。我有一个编译为MFC可执行文件的现有项目(我也对如何测试编译为DLL的项目感兴趣)。我对单元测试约定的理解是,您应该为您的测试创建一个新的单独项目。所以我在同一个解决方案中为我的单元测试创​​建了一个新项目。但是我如何链接这些项目?我可以从我的测试项目中测试我的exe项目的任意函数/方法吗?执行此操作的常规方法是什么? 最佳答案 我认为组织单一测试的最佳方式是:不要更改您的主要项目。该结构应该独立于您的测试操作。在我看来,将您

c++ - 从 boost::threaded 成员函数获取返回值?

我有一个像下面这样的worker类(Class):classWorker{public:intDo(){intret=100;//dostuffreturnret;}}它旨在与boost::thread和boost::bind一起执行,例如:Workerworker;boost::functionth_func=boost::bind(&Worker::Do,&worker);boost::threadth(th_func);th.join();我的问题是,如何获取Worker::Do的返回值?提前致谢。 最佳答案 另一种选择是使用

c++ - 为什么 C++ 中的静态 thread_local 对象构造了两次?

这段代码:#include#include#includestructSingl{Singl(Singlconst&)=delete;Singl(Singl&&)=delete;inlinestaticthread_localboolalive=true;Singl(){std::cout具有以下输出:Singl()2Singl()21~Singl()2~Singl()2我正在使用mingw-w64gcc7.2POSIX线程在Windows下编译和运行。Coliru有不同的输出:http://coliru.stacked-crooked.com/a/3da415345ea6c2ee这是

c++ - 如何将 Google Test 测试用例标记为 "expected to fail"?

我想为尚未实现的功能添加一个测试用例,并将此测试用例标记为“没关系,我失败了”。有办法吗?编辑:我希望执行测试,只要测试用例处于“预期失败”状态,框架就应该验证它是否失败。编辑2:好像我感兴趣的功能在google-test中不存在,但是theBoostUnitTestFramework中确实存在,并在LIT. 最佳答案 EXPECT_NONFATAL_FAILURE是您希望将预期失败的代码包装起来的内容。请注意,您必须包含gtest-spi.h头文件:#include"gtest-spi.h"//...TEST_F(testclas

c++ - clang thread_local 初始化中的错误

下面的代码应该只创建一次类内thread_local,但它最终会在每次访问时初始化它#include#includeusingstd::cout;usingstd::endl;templateclassSomething{public:structTLBookkeeping{TLBookkeeping(){std::coutthread_localtypenameSomething::TLBookkeepingSomething::bookkeeping_;templatevoidSomething::foo(){std::cout::foo();}(https://wandbox.o

c++ - 如何使用 boost::test 库组织测试用例?

我有一个包含50多个.H/.CPP文件/类的项目。我想用自己的测试用例来测试每个类,其中将包括用于测试每个类不同方面的方法。我的类位于不同的目录中,如下所示:/project/include/SuperModuleFoo.hFoo.cpp..Alpha.hAlpha.cpp../test//Iassumethatmytestsshallbeheremain.cppMakefile我想使用boost::test作为单元测试框架。我应该如何组织我的文件,我应该如何命名它们等等。一些提示或链接或建议将不胜感激。谢谢。 最佳答案 我们在类似

c++ - 来自 Parasoft C++test 的混淆控制流分析

我们使用ParasoftC++test静态分析我们的代码。它在使用如下代码时遇到问题:voidfoo(int*x){try{bar();}catch(...){deletex;throw;}*x;}它在*x;行警告:Freedmemoryshouldn'tbesubsequentlyaccessedunderanycircumstances不知何故得出结论,控制流可以传递到catch(...)block,删除x,经过throw;,并使其成为*x;。我尝试了throwstd::exception("");和其他几个,得到了同样的结果。Parasoft当然知道异常并将它们合并到其控制流中,

c++ - 如何在 Mac OSX clang 上获得对 thread_local 的支持?

如图thisanswer,即使设置了C++11标志,MacOSX上Xcode的clang也不支持thread_local存储。即使在最新版本上,AppleLLVM版本7.0.0(clang-700.1.76),目标:x86_64-apple-darwin15.0.0,线程模型:posix,不支持thread_local:../../src/dir/sysArch.h:1505:3:error:thread-localstorageisnotsupportedforthecurrenttargetthread_local^ 最佳答案

Java多线程 -Thread类的常用API

线程常用APIThread常用API说明:Thread常用方法:获取线程名称getName()、设置名称setName()、获取当前线程对象currentThread()。至于Thread类提供的诸如:yield、join、interrupt、不推荐的方法stop、守护线程、线程优先级等线程的控制方法,在开发中很少使用,这些方法会在高级篇以及后续需要用到的时候再为大家讲解。思考:当有很多线程在执行的时候,我们怎么去区分这些线程呢?例如下面代码,我们创建了两个子线程,但是两个子线程的打印内容是一样的,这就导致于我们无法区分两个子线程publicclassThreadDemo{publicstat

java - 对象: no thread state can be involved,的序列化对吗?

我正在认真研究将正在执行的程序的状态存储到磁盘并再次将其取回的基本原理。在我们当前的设计中,每个对象(这是一个带有函数指针列表的C级东西,一种低级的自制面向对象——这样做有很好的理由)将是调用以将其显式状态导出为可写和可恢复的格式。使这项工作有效的关键属性是与对象相关的所有状态确实封装在对象数据结构中。还有其他解决方案,您可以使用Activity对象,其中有一个用户级线程附加到某些对象。因此,程序计数器、寄存器内容和堆栈内容突然成为程序状态的一部分。据我所知,没有什么好的方法可以在任意时间点将此类内容序列化到磁盘。线程必须将自己停在某个特殊状态,其中程序计数器等不代表任何内容,因此基本