草庐IT

野指针

全部标签

c++ - 为什么下面的runner指针没有变为null?

为什么runner指针没有改成null?Node*runner=head->next;Node*reversedList=head;reversedList->next=nullptr;但在下面,它确实变为nullNode*reversedList=head;reversedList->next=nullptr;Node*runner=head->next; 最佳答案 在你发出下面的声明之后Node*runner=head->next;'runner'指向由'next'指向的地址内存(假设它是地址0x6543)。(head->nex

c++ - GCC 无法优化涉及成员函数指针的委托(delegate) lambda 函数

我使用GCC4.9.2和clang3.6.0编译了以下c++14代码。我使用了-O3标志。#includestructS{inta;intA()const{returna;}};templateintFunc(F&&f,Args&&...args){returnf(std::forward(args)...);}usingPtrA=int(S::*)()const;intF(Sconst&s,PtrAptr){return(s.*ptr)()*5;}intp(Sconst&s){returns.A()*5;}intP1(Sconst&s){returnFunc(&F,s,&S::A);

c++ - const 指针和 const 数组的输出

当我们有两个运算符用于输出对象和这些对象的数组,并尝试输出常量对象数组时,就会涉及到对象运算符。有没有办法强制数组的运算符与常量对象的c数组一起使用?示例代码:#include#includeusingstd::size_t;namespacenm{structC{inti;};templateusingc_c_array=C[N];inlinestd::ostream&operatorinlinestd::ostream&operatorconst&){returnlhs输出:1211此外,在我的例子中,2运算符使用1作为输出。 最佳答案

c++ - Cereal 不支持原始指针

编辑:问题标题是基于对我得到的编译器错误的深刻误解。我(愚蠢地)假设错误是,我试图反序列化到我在函数内部声明的对象。这是完全错误的。我自己没有做足够的调试工作,否则我本可以找出问题所在。所以标题很误导,我改了。感谢АндрейБеньковский的帮助。我正在使用cereal在我的引擎中为3D模型编写序列化函数,事实证明它非常高效且易于使用。到目前为止,当我测试(反)序列化一个简单的网格时,一切都很好。但现在我正在尝试反序列化另一个类,但遇到了一个我没有得到的问题。voidloadFile(std::stringfilepath){DescriptionFilefile;{ifstr

c++ - `std::shared_ptr` 的智能指针模拟,带有用于将回调绑定(bind)到引用计数修改事件的 API,例如释放/保留……这是一回事吗?

我需要一个智能指针结构-类似于std::shared_ptr-它为我提供了某种带有公开Hook的API,回调到引用计数修改事件(例如释放/保留,又名refcout增量/减量)可以绑定(bind)。我要么想自己实现,要么使用现成的东西,如果它存在的话。比如,我希望在定义这个假定的shared_ptr-ish智能指针(就像delete-expressions和deleterfunctor分别在shared_ptr和unique_ptr定义中使用。编辑(来self下面的评论)——这就是我想要这个的原因:我目前有一个Image类模板,在它的核心,有一个std::shared_ptr持有一个(可

c++ - 具有指向其父对象的指针的对象是否应该定义复制构造函数?

如果一个对象A包含一个成员对象B,并且对象B有一个指向其父对象A的指针,我是否需要为对象B指定一个复制构造函数?假设没有动态分配。此外,3的规则是否适用于此? 最佳答案 您的设计使用双向导航实现组合。这可能是完全有效的。然而,正如谢尔盖在评论中指出的那样,这样的设计并非没有问题。假设你有一个类Object和一类Container包含Object.这里有一些基本问题:Containerc;Objectmo1;//Q1:shouldthisbevalid?(i.e.isanobjectwithoutparentallowedObject

c++ - 在以抽象基类为参数的函数中将指针和赋值运算符与派生类一起使用

我有一个函数(modShape),它接受一个抽象基类(Shape)作为参数;在函数中,我想制作输入对象的拷贝,修改拷贝,然后将拷贝重新分配给输入对象,以便修改保留在modShape的范围之上。我已经设置了一个clone()成员函数来制作初始拷贝,它似乎运行良好。接下来,我使用doubleArea()成员函数修改拷贝,并尝试将其复制回输入对象。基类和派生类在header.h中定义:#ifndefHEADER_H_#defineHEADER_H_#include#includeusingnamespacestd;//Abstractbaseclass.classShape{public:/

c++打包和解包参数包以在没有STL的情况下调用匹配的函数指针

我正在尝试创建一个类,该类将存储指向具有可变数量参数的函数的指针,并在稍后调用它。想法是为函数创建一个包装器,该函数将在对象析构时调用所述函数。这样我就可以确保在退出某些功能后进行一些清理。我现在拥有的是FaheemMitha发布的一点修改代码here.这是带有示例的工作代码(我正在使用VisualStudio2015编译它):#include"stdafx.h"#include#includeusingnamespacestd;templatestructseq{};templatestructgens:gens{};templatestructgens{typedefseqtype

c++ - 将函数指针实现替换为 std::function 以在 PlayFab SDK 中使用 lambda

我目前正在尝试包含PlayFabC++SDK进入我的应用程序。该SDK主要针对游戏引擎Cocos2d-x,但基本上可以用于任何C++应用。它只是普通的REST,因此您向他们的服务器发送请求并等待响应。这非常适合使用lambda。他们声明了这个回调,当请求成功时调用:templateusingProcessApiCallback=void(*)(constResType&result,void*userData);不幸的是,他们没有使用std::function,而是一个函数指针。这样就不能使用捕获变量的lambda。因此,我想我可以简单地用std::function回调替换这个函数指针

c++ - 我应该在 v8::External 中手动删除指针吗?

Localtpl=ObjectTemplate::New(isolate);tpl->SetInternalFieldCount(1);Localret=tpl->NewInstance();TestExternal*ex=newTestExternal();ret->SetInternalField(0,External::New(isolate,ex));当ret不再使用时,我是否应该手动删除ex指针?表明我应该或不应该这样做的证据源代码在哪里? 最佳答案 是的,C++需要手动内存管理:如果您使用new手动创建一个对象,那么您还