草庐IT

weak_ptr_cast

全部标签

c++ - boost::smart_ptr 可以用于多态吗?

可以boost::smart_ptr比如scoped_ptr和shared_ptr可以用在多态中吗?classSomeClass{public:SomeClass(){a_ptr.reset(newSubClass);}private:boost::scoped_ptra_ptr;} 最佳答案 我相信答案是肯定的;对boost指针进行编码,以便在父类(superclass)所在的任何地方都接受派生类。 关于c++-boost::smart_ptr可以用于多态吗?,我们在StackOver

C++11 闭包 shared_ptr

创建由shared_ptr管理的堆分配闭包的语法是什么。我想将闭包传递给函数并能够传递nullptr。似乎使用了shared_ptr但我无法理解从lambda表达式初始化它的语法 最佳答案 应该是这样的autolambda=[](){/*dosomethingusefull*/};autop=std::make_shared>(lambda);但实际上你可能不需要shared_ptr,因为function可以从nullptr构造。std::functionfnc(nullptr); 关于

c++ - 在 C++/CLI 中使用 unique_ptr 时出现链接器错误

我目前正在转换我的auto_ptr实例至unique_ptr,但我遇到了一个问题。它在代码的C++部分工作得很好,但在我的托管C++/CLI层(该软件同时使用C#和C++)中执行它时,我遇到链接错误。它编译得很好,但在链接时会中断。auto_ptr从来没有任何问题.我目前正在使用VisualStudio2010。有人知道使用unique_ptr时遇到的任何问题吗?在C++/CLI中?我试图在下面的一段代码中总结我的问题,但请注意下面的代码实际上可以编译和工作(我检查了指针的所有权是否正确移动).编译时我没有收到链接错误,但下面的代码是纯C++而不是C++/CLI。我只是想提供一个代码构

c++ - 将_cast 重新解释为 void 是否合法*

我在看https://en.cppreference.com/w/cpp/language/reinterpret_cast我注意到它指定了我们始终可以转换为的合法类型:字节*char*unsignedchar*但是我没有在列表中看到void*。这是疏忽吗?我的用例需要reinterpret_cast,因为我正在从int**转换为void*。我最终将从void*转换回int**。 最佳答案 这些类型不受严格的别名规则约束。这并不意味着它们是您可以与reinterpret_cast一起使用的唯一类型.在将对象指针转换为另一种对象指针类

c++ - 如何传递 unique_ptr<T> 代替原始 *output* 指针参数?

我在外部库中有一个预先存在的函数,它看起来像这样;boolCreateTheThing(MyThing*&pOut);简而言之;我给它一个原始指针(通过引用),函数分配内存并将我的指针分配给新分配的对象。当函数返回时,我有责任在我完成后释放内存。显然,我想将此结果存储到unique_ptr中,并避免使用手册delete.我可以创建一个临时原始指针以用于API调用,并将其传递到unique_ptr的构造函数中;MyThing*tempPtr;CreateTheThing(tempPtr);unique_ptrrealPtr=unique_ptr(tempPtr);还有比这更直接的方法吗?

c++ - 为什么类 std::weak_ptr 没有运算符 <?

这个问题在这里已经有了答案:HowcanIuseastd::mapwithstd::weak_ptraskey?(2个答案)关闭4年前。我在map中使用弱指针作为键。然而,当我尝试编译时,我得到了丑陋的消息,我将其解释为我缺少std::weak_ptr的比较运算符,这显然是std::map所必需的,因为它根据以下命令对其元素进行排序键值。但是,现在weak_ptr类是一个智能指针类型类,因此可以使用指向某些托管数据的指针。这个类不提供operator在这里,您的见解将不胜感激。感谢期待。

c++ - const_cast 是否会导致实际的代码排放?

const_cast真的只是告诉编译器“停止提示,将其视为非常量指针”的一种方式吗?有没有const_cast本身被翻译成实际机器代码的情况? 最佳答案 不,它只是在编译时删除了const属性。 关于c++-const_cast是否会导致实际的代码排放?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/759315/

c++ - 初始化 boost::scoped_ptr 数组的正确方法?

我有一个类,其中有一个范围指针数组,这些指针指向没有默认构造函数的对象。我发现“初始化”它们的唯一方法是像这样使用swap():classBar{Bar(char*message){};}classFoo{boost::scoped_ptrarr[2];Foo(){arr[0].swap(boost::scoped_ptr(newBar("ABC")));arr[1].swap(boost::scoped_ptr(newBar("DEF")));};}这感觉有点冗长和笨拙。我错过了更聪明的方法吗? 最佳答案 arr[0].reset

c++ - 这是在 C++11 中使用 unique_ptr 和移动语义实现 pimpl 的正确方法吗

我还没有看到同时使用unique_ptr和移动语义的pimpl示例。我想向STL派生容器添加一个CHelper类,并使用pimpl隐藏CHelper的功能。这样看起来对吗?派生.hclassCDerived:publicset,publicCHelper{//...};`Helper.h//derivedcontainersneedtosupportbothcopyandmove,soCHelperdoestooclassCHelper{private:classimpl;unique_ptrpimpl;public://---default:needbothcotr&cotr(com

c++ - 当编译器看不到可以完成转换的可能类型时,是否允许编译器优化 volatile 指针的 dynamic_cast?

看看这个小片段:structA{virtual~A(){}};structB{};boolfn(){A*volatilea=newA;returndynamic_cast(a);}是否允许编译器完全删除dynamic_cast,并将dynamic_cast转换为简单的nullptr;?这个问题的原因是这个answer.注意事项:假定volatile意味着编译器不能假定任何有关a的信息,因为它是易变的。这是一个question为什么。dynamic_cast可能不允许被删除的事实是程序中某处可能有一个类型,它派生自A和B。 最佳答案