草庐IT

make_links_absolute

全部标签

c++ - C++ 中的 "As a rule of thumb, make all your methods virtual"- 合理的建议?

我只是偶然看到了标题中的陈述。完整的报价是:Asaruleofthumb,makeallyourmethodsvirtual(includingthedestructor,butnotconstructors)toavoidproblemsassociatedwithomissionofthevirtualkeyword.我在Wrox的书ProfessionalC++中找到了这个。Youcangoogleittocheck.这有什么关系吗?我原以为您只会提供选择的扩展点,而不是默认的可扩展性。例如,a2001articlebyHerbSuttersaysso.从那以后,有什么发生了巨大

c++ - 使 : implicit rule to link c++ project

我正在学习制作教程。我正在尝试构建的非常简单的测试项目只有3个文件:./src/main.cpp./src/implementation.cpp和./include/header.hpp这是制作文件。VPATH=srcincludeCPPFLAGS=-Iincludemain:main.oimplementation.omain.o:header.hppimplementation.o:header.hpp在不带任何参数的情况下调用ma​​ke仅构建目标文件,但不链接可执行文件。prog应该有一个隐含的规则,或者我错过了什么?我真的需要有人为我指明正确的方向。谢谢。我使第一个目标名称与

c++ - 为什么 boost 没有 make_scoped()?

Boost的make_shared()函数promise在尝试创建shared_ptr时是异常安全的.为什么没有make_scoped()相等的?是否有通用的最佳做法?这是来自boost::scoped_ptrdocumentation的代码示例这对我来说似乎不安全:boost::scoped_ptrx(newShoe);这行代码会依次完成这三件事:为Shoe分配堆内存调用Shoe的构造函数调用boost::scoped_ptr的构造函数如果Shoe的构造函数抛出异常,内存将被泄露。(参见R.MartinhoFernandes的回答)scoped_ptr不会处理释放,因为它还没有被构造

c++ - 如何make_shared派生类?

我想使用make_shared带有派生类的函数,如下所示classBase{public:typedefstd::shared_ptrPtr;};classDerived:publicBase{};Base::PtrmyPtr=std::make_shared(/*Derived()*/);我如何告诉make_shared构建这样一个对象?我想避开经典Base::Ptrptr=Base::Ptr(newDerived());利用make_shared函数中的单个alloc。 最佳答案 std::shared_ptr有一个可以生成sh

c++ - make_unique数组,原始提案与最终提案

StephanTLavavej最初对make_unique的建议是N3588它包括以下功能:make_unique(args...)make_unique_default_init()make_unique(n)make_unique_default_init(n)make_unique_value_init(n,args...)make_unique_auto_size(args...)但是,最后的提案N3656仅包含make_unique(两种形式)。我找不到有关该函数其他形式的任何讨论。我读了theminutesoftheBristolmeeting,但他们甚至都没有引用原始建议

C++ Visual Studio : linking using pragma comment

我遇到了一段使用#pragmacomment(lib,"libraryname")的代码。为什么要使用这种类型的用法,而不是仅从属性菜单链接库?在什么情况下需要这种用法?我在Windows中使用C++Visual Studio 2010.很高兴看到一个需要这种用法的示例。 最佳答案 库编写者可以在公共(public)头文件(.h)中放置#pragmacomment(lib,...)命令。在这种情况下,客户端不需要将此库添加到链接器依赖项列表中。通过在程序中包含一个h文件,客户端会自动链接到所需的库。

c++ - std::make_shared 与 std::initializer_list

#include#includeclassBase{public:Base(){}};classDerived:publicBase{public:Derived(){}Derived(std::initializer_list>>){}};intmain(intargc,char**argv){autoexample=newDerived({{0,std::make_shared()}});return0;}它正常工作(livepreview),但是当我尝试使用std::make_shared和std::initializer_list作为参数时,我得到了错误:autoexample

c++ - C++ 标准中与 [basic.link]/7 相关的 GCC 和 clang 之间的矛盾结果

这段代码在clang中编译,namespaceA{voidf(){voidg();g();}}voidA::g(){}但如果g在命名空间A中定义如下,GCC只接受代码:namespaceA{voidf(){voidg();g();}voidg(){}}但我相信[basic.link]/7中没有任何内容不允许上面的第一个片段。 最佳答案 [basic.link]/p7,强调我的:Whenablockscopedeclarationofanentitywithlinkageisnotfoundtorefertosomeotherdecl

c++ - 如何使用 link.exe 进行静态链接

我一直在尝试静态链接一个名为Poco的C++库。在Windows上使用VisualStudio2008命令行工具。我构建我的程序:cl/I..\poco\lib/cmyapp.cpplink/libpath:..\poco\libmyapp.objPocoNet.lib这会导致运行时需要PocoNet.dll和PocoFoundation.dll的exe。我花了一些时间阅读Windows中的链接,并了解到cl/MT静态链接到标准库,而cl/MD链接动态。我尝试指定/MT,但这似乎并没有改变任何东西;我的应用程序仍然需要PocoDLL。(我也怀疑/MT是默认行为。)查看..\poco\l

c++ - 什么会导致 "corrupted double-linked list"错误?

我在处理相当复杂的代码时遇到了问题。我无法生成重现错误的简短片段,因此我将尝试用文字解释问题。代码随机崩溃并出现错误***glibcdetected***gravtree:corrupteddouble-linkedlist:0x000000001aa0fc50***调试表明它来自代码释放对象的行。该对象似乎没有任何问题。它存在,我可以在错误发生时访问它的数据。对象的析构函数是微不足道的,不做任何事情。所以,我有点卡住了。您认为“免费”在何种情况下会失败? 最佳答案 尝试在Valgrind下运行您的程序.它可能会为您指出更早的原因,