草庐IT

libboost_unit_test_framework-vc

全部标签

c++ - 解决 VC++12 中的模板特化错误?

我有一些为Clang3.2编写的代码,我正试图将其移植到VC++12中运行。Clang3.2+和GCC4.8没有问题,但VC++12有问题。这是产生问题的最小片段:templateclassfoo{};templateintReturnsN(){returnN;}templateclassbar{typedeffoo>fooN;};现在我很确定这是一个编译器错误(但如果不是,请告诉我!)给出的错误是:'specialization':cannotconvertfrom'int(__cdecl*)(void)'to'int(__cdecl*)(void)'那么有人知道一个体面的工作吗?编

c++ - 为什么 Google Test/Mock 通过 std::unique_ptr 显示泄露的模拟对象错误?

假设有一个Bar对象,它使用了一个Foo对象。所有权是独占的,因此Bar在其构造函数中将Foo作为std::unique_ptr获取。我想用Google测试框架测试Bar,所以我编写了以下代码:usingnamespacetesting;classFoo{public:virtualintF()=0;};classBar{public:Bar(std::unique_ptr&&foo):m_foo(std::move(foo)){}intB(){returnm_foo->F();}private:std::unique_ptrm_foo;};classMockFoo:publicFoo

c++ - VC++ 中的动态数组大小和动态数组分配器

在编写自己的小型发现程序以弄清楚VisualC++如何为动态数组分配内存时,我有点困惑。我必须指出,我从未见过描述任何C++实现的new[]/delete[]运算符的这个问题的技术文档。一开始我以为new[]和delete[]如果解释成简单的C的话就是类似下面的东西:voidfake_int_ctor(int_this){printf("bornswith0x%08Xintheheap\n",_this);}voidfake_int_dtor(int_this){printf("dieswith%d\n",_this);}void*new_array(unsignedintsingle

Android单独编译framework模块

一、如果修改了frameworks/base/services目录下的代码,比如你在PhoneWindowManager修改了部分代码,这时候可以通过单编译的方式快速烧录到指定机器,无需系统全编前提:如果需要单编译,需要先全编一下系统,再进行单编译步骤:1.首先需要进入frameworks/base/services下,打开Android.bp...//mergeallrequiredservicesintoonejar//============================================================java_library{name:"service

c++ - C++ 中的奇怪编译器错误(VC 编译器)

对于这段代码,#includeintmain(){floatx=1.5f;floaty=0.0f;/*line6*/y=pow(x,6)*235809835.41-pow(x,5)*2110439254.2+pow(x,4)*7869448124.8-pow(x,3)*15648965509+pow(x,2)*17503313074-(x)*10440563329+2594694745‏;//error/*line7*/y=pow(x,6)*235809835.41-pow(x,5)*2110439254.2+pow(x,4)*7869448124.8-pow(x,3)*1564896

c++ - 设置 Google Test 时找不到 -lgtest

我正在使用GoogleTestforC++并尝试在我的Linux机器上进行设置。我的make文件包含以下代码:CC=g++CFLAGS=-I$(GOOGLETESTDIR)/include-L$(GOOGLETESTDIR)/lib-lgtest-lpthread-WallDEPS=fib.hOBJS=fib.omain.oall:|r6clean:-rm-fr6$(OBJS)%.o:%.cpp$(DEPS)$(CC)-c-o$@$运行make时出现错误:/usr/bin/ld:cannotfind-lgtest我该如何解决这个问题?我对这种测试很陌生,对Linux也很陌生,所以我真的

c++ - 如何指示 VC++ 编译器不内联常量?

我的C++程序中有以下全局常量:constintK=123456;当我编译程序时,生成的可执行文件在所有使用该值的地方(数十次)都包含文字值123456。但是,如果我删除const限定符,值123456在整个可执行文件中只出现一次(在.data部分).这是我正在寻找的结果。我希望值123456只出现一次,以便只需使用十六进制编辑器编辑.exe文件即可更改它。但是,我不想删除const限定符,因为我希望编译器防止我不小心修改源代码中的常量。是否可以指示编译器以某种方式不内联所述常量的值?我需要这样做的原因是,可执行文件很容易被负责“破解”示例程序以改变其行为的学生修改。对于没有经验的人来

c++ - 为什么 istream_iterator<string>(ifstream ("test.txt")) 会导致错误?

我尝试编写代码从名为“test.txt”的文件中读取字符串并将字符串写入标准输出。下面的代码运行良好:intmain(){usingnamespacestd;ifstreamfile("test.txt");copy(istream_iterator(file),istream_iterator(),ostream_iterator(cout,""));}但是,通过此修改,代码不再编译:intmain(){usingnamespacestd;copy(istream_iterator(ifstream("test.txt")),//(),ostream_iterator(cout,""

c++ - 为什么VC++引入非标准关键字: __leave?

根据MSDN:The__leavestatementismoreefficientbecauseitdoesnotcausestackunwinding.以我的理解,就是说:“这样一个普通的代码片段是危险的!”structA{int*p;A():p(newint){}~A(){deletep;}};voidf(){__try{Aa;...//Doingsomthingif(thethinghasgonebad)__leave;...//Continue}__finally{}}在C++项目中完全避免__leave是最佳实践吗? 最佳答案

c++ - 为什么 virtual void test()=00 有效但 virtual void test()=+0 和 virtual void test()=-0 无效?

我搜索了一些关于虚函数声明的帖子,相信=0在virtualvoidtest()=0;是固定句法所以virtualvoidtest()=NULL;virtualvoidtest()=false;virtualvoidtest()=1-1;virtualvoidtest()=0.0;和其他声明应该是无效的。但是我发现了virtualvoidtest()=00;virtualvoidtest()=000;virtualvoidtest()=0000;还能编译,为什么?还有,我觉得整数+0和-0其实和0一样(不知道对不对),就像00其实就是0一样,为什么virtualvoidtest()=+0