草庐IT

vs-cmake-examples

全部标签

C++ 多重继承和向上转换的智能指针销毁导致 VS 2017 中的堆损坏

我在使用上面的代码时遇到了VS调试器的问题:classAnimal{public:};classStupid{public:};classDog:publicStupid,publicAnimal{public:};intmain(){std::unique_ptranimal=std::unique_ptr(newDog());animal.reset();return0;}此代码在执行涉及“ntdl.dll”和“wntdll.pdb”的“animal.reset()”后抛出错误。如果我点击“忽略”多次(3)次,以下是MSVC运行时库生成断言失败的表达式:1-_CrtIsValidH

c++ - cmake 引用了以下导入的目标,但丢失了

我有一个包含两个库(liba和libb)的存储库,而liba取决于libb。它们是单个存储库的一部分,并且是使用单个cmake“上下文”构建的。文件结构如下所示:├──CMakeLists.txt├──liba│├──CMakeLists.txt│├──internal││└──private.hh│├──module.cc│├──module.hh└──libb├──CMakeLists.txt├──other.cc└──other.hh一切都编译和安装没有任何问题。虽然,如果我尝试创建一个依赖于liba的新项目。像这样:cmake_minimum_required(VERSION3

c++ - 模板参数阴影在 VS2005 中如何工作?

在GCC中,这段代码无法编译,因为T被隐藏了,但是在VS2005中,它编译时没有警告,那么VS编译器所做的假设是什么?templateclassFoo{templatevoidBar(constT&bar){...}}; 最佳答案 经过3个月的搜索找到了正确的答案:)它在标准的14.6.1/4中:Atemplate-parametershallnotberedeclaredwithinitsscope(includingnestedscopes).Atemplate-parametershallnothavethesamenamea

c++ - <hash_set> 相等运算符在 VS2010 中不起作用

示例代码:std::hash_seths1;//alsoitrystd::unordered_set-sameeffectstd::hash_seths2;hs1.insert(15);hs1.insert(20);hs2.insert(20);hs2.insert(15);assert(hs1==hs2);hash_set不按照散列函数定义的某种顺序存储元素...为什么?请注意,此代码使用stdext::hash_set在VS2008中工作。 最佳答案 在VisualC++2010中,hash_set和unordered_set的

C++,重载 std::swap,编译器错误,VS 2010

我想在我的模板类中重载std::swap。在下面的代码中(简化)#ifndefPoint2D_H#definePoint2D_HtemplateclassPoint2D{protected:Tx;Ty;public:Point2D():x(0),y(0){}Point2D(constT&x_,constT&y_):x(x_),y(y_){}....public:voidswap(Point2D&p);};templateinlinevoidswap(Point2D&p1,Point2D&p2){p1.swap(p2);}namespacestd{templateinlinevoidsw

c++ - 使用 CMake 制作跨平台库?

CMake难用吗?我一直在使用Windows和MSVC++开发一个库。我在Linux和OSX中测试了我的代码,方法是从每个文件中繁琐地创建对象并从中创建一个库。我有几个目录例如:Agui->Widgets->Button->ListBox->Backends->Allegro我想要的是,例如,如果我在Windows上,它会自动生成一个msvc项目,其中包含所有这些目录和文件,并准备好进行编译。在Linux和OSX上我希望能够做类似的事情制作制作使用CMake可以做到这一点吗?考虑到我的情况,这很容易做到。谢谢 最佳答案 是的,这正是

c++ - 从 C#/Java 到 C++ : Understanding C++ references in an example?

来自C#/Java背景,我正在尝试了解使用C++指针和引用的最佳实践。我敢肯定这已经在这个网站上被令人作呕地覆盖了,但我仍然不完全理解它。我已经阅读了一些C++常见问题解答,但我需要在上下文中查看它。假设我有两个类:classEmployee{Employee();~Employee();}classCompany{Company();~Company();AddEmployee(??employee);??GetEmployee();private:std::listemployees_;}在哪里AddEmployee获取一个员工对象并将其添加到员工的私有(private)列表中。A

c++ - sqlite3_bind_text SQLITE_STATIC vs SQLITE_TRANSIENT for c++ string

我有一个返回c++std::string的方法,然后在将其传递到sqlite3_bind_text之前将其转换为c_str()。我的问题是,这应该使用SQLITE_STATIC还是SQLITE_TRANSIENT?sqlite3_bind_text(insertStatement,0,suspect->GetIpString().c_str(),-1,SQLITE_STATIC);//Dosomestuffinsamefunctionthensqlite3_stepsqlite3_bind_text的文档说,Thefifthargumenttosqlite3_bind_blob(),s

com.sabre.redapp.example.pnr示例在哪里

3.2RC1SDK中的帮助提到了样本(com.sabre.redapp.example.pnr)可以访问PNR,但是该代码在样本中不可用。这似乎是SDK3.0+的重要功能。可以在其他地方找到样品吗?该样本表明访问PNR和令人耳目一新的旅行摘要。当您的工作空间中有一个PNR时,您可以在“getpnr”按钮上clik获取当前PNR的内容。结果将显示在左侧的文本区域中。当您需要刷新旅行摘要时,请单击“刷新旅行摘要”按钮。您将在左侧的文本区域中看到刷新请求状态。注意:刷新旅行摘要仅在SaberRedWorkspace3.0中。在2.0中,它没有效果。看答案您是对的,RC不包含此示例代码。这将在我们的下

在自定义类中移动vs副本性能

与复制CTOR相比,(如果有的话)如何通过MoveCTOR提高性能创建类实例ctor?那么,在处理自定义课程时,移动何时提供更好的性能?看答案与复制CTOR相比,(如果有的话)如何通过MoveCTOR提高性能创建类实例ctor?如果所有成员变量都是副价值/POD的情况,则根本没有任何区别。那么,在处理自定义课程时,移动何时提供更好的性能?移动构造函数仅在新构造的对象可以从已经存在的对象“窃取”资源的情况下才能提供优势。例如,想象一下您有一个暂时的std::string其中包含了小说“战争与和平”的全部内容-所有1440页。在经典的复制构造案例中,如果您想将该临时字符串分配给非贴工std::st