草庐IT

Shared-Preferences

全部标签

c++ - 为什么让 operator new 私有(private)中断 std::shared_ptr?

我正在实现一个多态类型(称之为A),我想通过std::shared_ptr专门管理它。为了允许在派生类的构造函数中使用shared_from_this,A使用new分配,然后初始化一个成员std::shared_ptr给自己自动管理它的生命周期。为了帮助实现这一点,我决定将类特定的operatornew设为私有(private),并计划使用create()辅助函数而不是new和make_shared。该设计可能看起来有点滑稽,但在我正在处理的UI库的上下文中是有意义的。一个最小的可重现示例如下:structA{A():m_sharedthis(this){}voiddestroy(){

c++ - 为什么 shared_ptr 需要保存 weak_ptr 的引用计数?

引自C++Primer$12.1.6:Aweak_ptr(Table12.5)isasmartpointerthatdoesnotcontrolthelifetimeoftheobjecttowhichitpoints.Instead,aweak_ptrpointstoanobjectthatismanagedbyashared_ptr.Bindingaweak_ptrtoashared_ptrdoesnotchangethereferencecountofthatshared_ptr.Oncethelastshared_ptrpointingtotheobjectgoesaway,t

c++ - shared_ptr 需要完整的类型;不能与 lua_State 一起使用*

我正在为Lua编写C++/OOP包装器。我的代码是:classLuaState{boost::shared_ptrL;LuaState():L(luaL_newstate(),LuaState::CustomDeleter){}}问题是lua_State是不完整的类型,而shared_ptr构造函数需要完整的类型。我需要安全的指针共享。(有趣的是,boost文档说大多数函数不需要完整类型,但构造函数需要,所以没有办法使用它。http://www.boost.org/doc/libs/1_42_0/libs/smart_ptr/smart_ptr.htm)我能解决这个问题吗?谢谢。

c++ - shared_ptr - 按值传递与按引用传递

假设我有:typedefboost::shared_ptrEventPtr;在一个线程上,我正在创建一个Event并将其发送出去以进行分派(dispatch):Event*event=newEvent();EventPtreventPtr(event);EventDispatcher::dispatch(eventPtr);//pseudocodeEventDispatcher接收一个EventPtr并将其添加到一个队列中,该队列在另一个线程中进行处理...但是什么是适合调度方法的方法签名?dispatch(EventPtrevent);//willpush_back(event)或d

c++ - 确保抽象基类是一个 shared_ptr

我有一个抽象基类:structBase:std::enable_shared_from_this{virtual~Base()=default;virtualvoidfoo()=0;voidbar(){baz(shared_from_this());}};Base的唯一有效用例是存在于shared_ptr中-bar是一个重要的方法。我怎样才能确保以下情况是不可能的:structBadDerived:Base{voidfoo()override{...}};BadDerivedbd;bd.bar(); 最佳答案 一种技术是将Base的

c++11 - std::shared_ptr 和 dlopen(),避免未定义的行为

dlopen()是一个C函数,用于在运行时动态加载共享库。如果您不熟悉,该模式是这样的:调用dlopen("libpath",flag)得到void*handle去图书馆调用dlsym(handle,"object_name")得到void*object到图书馆想要的东西用object做你想做的事调用dlclose(handle)卸载库。在C++中,这是std::shared_ptr的所谓别名构造函数的完美用例。.模式变为:构造一个std::shared_ptrhandle来自dlopen("libpath",flag)那会调用dlclose()当它的析构函数被调用时构造一个std::

c++ - 将 GoogleMock 与 Boost::Shared Pointers 一起使用时泄漏的模拟对象

对于这种特殊情况,我无法消除泄漏。我在执行测试时收到了LeakedMockObjects的消息。具体消息:ClassElementFixture.h:102:错误:这个模拟对象(在测试ClassElementFixture.initialize中使用)应该被删除,但从来没有被删除。它的地址是@0x940a650。我标记了错误所指的行。这是我的代码的简化版本:...classClassElementFixture:public::testing::Test{public:boost::shared_ptrclassElement_;boost::shared_ptrdeviceEleme

c++ - shared_ptr 和私有(private)继承

这是一个说明我遇到的问题的玩具示例。该应用程序是相当无关紧要的(它本质上是一个链表元素,最后具有特殊行为)。我无法使用派生指针构造基类shared_ptr并且由于某种原因与我使用私有(private)继承的事实相关联。#include#include#includeusingnamespacestd;//AnIteminalinkedlistclassA{public://friendclassB;typedefboost::shared_ptrAPtr;A():next_(){}A(APtrn):next_(n){}APtrnext(){returnnext_;}voidsetNex

c++ - 如果 shared_ptr 的构造函数失败会怎样?

如果我理解正确,当使用指向新分配对象的指针初始化shared_ptr(来自boost、tr1、std等)时,shared_ptr的构造函数分配少量内存来保存指针的引用计数它管理。如果分配失败会怎样?在以下代码中:classmy_class{};voidmy_func(shared_ptrarg);intmain(intargc,char*argv[]){my_func(shared_ptr(newmy_class()));return0;}...如果shared_ptr未能为其引用计数分配内存,my_class对象是否会泄漏?还是shared_ptr的构造函数负责删除对象?

c++ - 使用 make_shared 和 make_unique 时需要检查 nullptr 吗?

如果我使用make_shared或make_unique创建指针,我是否必须检查它是否为nullptr,例如:std::unique_ptrp=std::make_unique();if(p==nullptr){........}如果您真的内存不足,std::make_unique将通过预期。所以你永远不会从std::make_unique得到空指针。这是正确的吗?所以在执行make_shared和make_unique时不需要检查nullptr吗? 最佳答案 来自std::make_unique上的cppreference(类似于