jjzjj

smart-pointers

全部标签

c++ - 函数返回 auto 自动参数 munmap_chunk() : invalid pointer

我正在测试newfeature对于GCC4.9(自动输入参数)并出现一些奇怪的错误。#include#includeautofoo(autov){for(auto&&i:v)std::cout{1,2,3});}这给我以下错误:***glibcdetected***./a.out:munmap_chunk():invalidpointer:0x00007f87f58c6dc0***=======Backtrace:=========/lib/x86_64-linux-gnu/libc.so.6(+0x7e846)[0x7f87f4e4c846]./a.out[0x400803]/lib

c++ - 为什么将 "pointer to pointer to non-const"转换为 "pointer to pointer to const"是不合法的

将非const指针转换为const指针是合法的。那为什么将指向非const的指针转换为指向const的指针是不合法的呢?例如,为什么下面的代码是非法的:char*s1=0;constchar*s2=s1;//OK...char*a[MAX];//akachar**constchar**ps=a;//error! 最佳答案 来自标准:constcharc='c';char*pc;constchar**pcc=&pc;//notallowed*pcc=&c;*pc='C';//wouldallowtomodifyaconstobject

c++ - 使用 stxxl 队列时为 `pointer being freed was not allocated`

我的代码似乎可以工作(由于上述错误,我还没有在大型数据集上尝试过)。代码:#include#include#includeintmain(){//queueq;//thisworksstxxl::queueq;//doesnotworkfor(inti=0;i我的简单.stxxl就是:disk=./testfile,0,syscall但我的错误是:stackexchangeexample(3884)malloc:***errorforobject0x101c04000:pointerbeingfreedwasnotallocated***setabreakpointinmalloc_e

当 C++ 使用智能指针时,C# 委托(delegate)等效

我主要是一名从事C++项目的.NET程序员,我正在尝试确定处理使用Action和Function模板类型的委托(delegate)的等效方法。我将委托(delegate)用作.NET代码中的事件和回调。我的C++项目使用智能指针和与C#程序相同的委托(delegate)设计模式。处理这种情况的最佳方法是什么?我不清楚如何传递和维护一个函数指针,该函数指针还跟踪智能指针并可能删除底层对象,因为事件容器使用弱引用。该库需要是多平台的,因此不幸的是,使用CLR不是一种选择。 最佳答案 您正在寻找的是绑定(bind)到现有对象的方法指针,就

c++ - 单一所有者和多个引用的智能指针

回到过去,我使用原始指针实现链表和树。当我尝试使用智能指针实现时,我遇到了以下问题,因为我不知道如何使用只有一个所有者但有0个或多个引用的指针:举一个二叉树的例子:对于初学者来说,节点应该是指针的唯一“所有者”:节点与树一起生死,所以对我来说,让它们成为unique_ptr是有意义的而不是shared_ptr:classTree{std::unique_ptrroot_;}classNode{std::unique_ptrleft_child_,right_child_;}然后我不得不做一个这样的算法:Node*node=root_.get();//left_countright_co

c++ - 在 C++ 中,是否允许删除 list<Pointer>::unique 中的对象

我们有遗留代码,它返回巨大的原始指针列表到堆分配的对象(我们不能使用智能指针),我们将从列表中删除重复项,并将它们从堆中删除。现在,正如专家建议的那样,我想尝试std::list::unique(或forward_list::unique)而不是算法std::unique。我读过http://en.cppreference.com/w/cpp/container/list/unique在'unique'谓词中我们不应该改变对象,那么根据标准术语删除list::unique中的“将要被删除的”对象是否安全?如果是这样,list::unique中的哪个对象应该被视为重复项?在gnu实现中,

c++ - 如何从 std::array<T, N>::pointer 成员/依赖类型中推断出数组大小?

我的目标是为strcpy编写安全的替代品对于在编译期间已知目标缓冲区大小的情况,我希望推断出缓冲区大小,因此用户不需要知道它。例如:charxs[2]={0};strcpy(xs,"abc");//bufferoverflow!printf("[%s]\n",xs);此输出(希望)是:[abc]对于简单的情况,当传递C风格的数组时,可以毫不费力地写成:templatechar*safe_strcpy(char(&dst)[N],constchar*src)noexcept{std::snprintf(dst,N,"%s",src);return&dst[0];}推导出数组的大小,snp

c++ - 支持多态的Stored-by-Value Pool,如何使用智能指针?

介绍我有一个数据结构:值池。(不是指针池)当我调用create()时,它会返回Handle。到目前为止一切都很好。templateclassPool{std::vectorv;//storebyvalueHandlecreate(){....}}templateclassHandle{Pool*pool_;//pointerbacktocontainerintpool_index_;//whereIaminthecontainerT*operator->(){returnpool_->v.at(pool_index_);//i.e."pool[index]"}voiddestroy()

c++ - 使用智能指针制作哈希表?

我正在尝试使用智能指针制作哈希表,但我不确定我做的是否正确。我一直在尝试使用它们的两种组合,但恐怕我不知道如何将表格初始化为空?也许这是错误的措辞,但我被卡住了,我需要指出正确的方向。我的哈希节点:struct{hashNode(intk,std::stringi):key(k),item(i){};intkey;std::stringitem;}我的哈希表:classHashtable{public:Hashtable();//notsurehowtobuildtheconstructorbuildanemptytable.inthashFunction(intkey);intfin

c++ - 构造函数中的 weak_from_this()

我知道您不能在构造函数中使用shared_from_this。但是可以在构造函数中使用新的weak_from_this吗?根据cppreference:Thisisacopyofthetheprivatemutableweak_ptrmemberthatispartofenable_shared_from_this.http://en.cppreference.com/w/cpp/memory/enable_shared_from_this/weak_from_this我没有看到从构造函数中获取内部存储的weak_ptr拷贝的问题,但我可能遗漏了一些东西,所以我不确定这一点。