草庐IT

$双指针

全部标签

c++ - 为类存储指向另一个类的指针复制构造函数析构函数和赋值运算符

我是新来的,这是我的第一个问题。我对我的家庭作业有疑问。我被要求设计一个抽象类“Base”,它由类“Sub”继承(在作业中有sub1、sub2等,但我试图尽可能地缩小它的范围)。然后,我应该设计一个类“BasePtr”,它存储一个指向“Base”对象的指针。最后,baseptr:s将存储在std::vector中,并使用ostream_iterator和复制写入文件。然后应使用ifstream_iterator读取该文件,并将其存储在std::list中。我已经解决了上述问题,但在实现析构函数、复制构造函数和赋值运算符时遇到了一些问题(因为我在我的BasePtr类中动态分配内存,我相信

c++ - 从 CUDA 内核访问全局内存指针

我正在尝试分配设备内存并将指针存储为全局变量。但是,当我尝试从内核访问内存时,我从cudaDeviceSynchronize()收到此错误:cudaErrorIllegalAddress。我检查了从cudaMalloc和cudaMemcpy返回的cudaStatus代码,它们都成功了。我希望下面的示例足够直截了当,足以说明我想做什么。基本上,我有大量示例数据,我希望所有内核都能从中读取这些数据,但我不想每次都必须将指针传递给内核调用。我正在使用Windows8x64,使用VisualStudio2012和nvcc(通过VS集成)编译代码。目标是x64调试可执行文件。我的设备是GTX78

c++ - 派生类不能使用指向 protected 基类成员的成员指针

includeclassBase{protected:intfoo;intget_foo(){returnfoo;}};classDerived:publicBase{public:voidbar(){intBase::*i=&Base::foo;this->*i=7;printf("foois%d\n",get_foo());}};intmain(){Derivedd;d.bar();}我不明白为什么我的派生类型不能指向基类的protected成员。它有权访问该成员。它可以调用类似作用域的函数。为什么它不能创建一个成员指针?我正在使用gcc4.1.2,但出现此错误:test.cc:I

c++ - 推断函数指针或仿函数的返回类型

我正在尝试推断可调用类型的返回类型,即函数指针或仿函数。我之前问过并得到了一个答案,展示了如何为函数指针执行此操作,并提示如何为仿函数执行此操作。FunctionreturntypedeductioninC++03基于此,我有了这个辅助结构,它现在适用于仿函数,但不再适用于函数指针。//functorstemplatestructReturn;{typedeftypenameT::result_typetype;};//functionpointerstemplatestructReturn{typedefRtype;};这适用于提供result_type的合作仿函数typedef但不

c++ - 现代 C++ 中对唯一指针的引用

这个问题在这里已经有了答案:shared_ptristoweak_ptrasunique_ptristo...what?(9个回答)关闭7年前。我有一个对象Window,它有一个成员std::unique_ptr.我使用一个唯一的指针,因为Window确实拥有纹理,并且在Window被销毁后使用所述纹理没有意义。窗口有一个方法,Texture&Window::getTexture().这个想法是有时Window外部的代码会说myWindow.getTexture(),对纹理做一些事情,然后完成它。风险在于有人持有在Window销毁后变得无效的纹理引用。我可以让窗口保持std::shar

c++ - 指向堆栈分配对象和 move 构造的指针

注意:这是对aquestion的完整改写我前一阵子发帖了。如果您发现它们是重复的,请关闭另一个。我的问题很普遍,但似乎可以根据具体的简单示例更容易地解释它。所以想象一下,我想模拟办公室的电力消耗。假设只有灯和暖气。classSimulation{public:Simulation(Timeconst&t,doublelightMaxPower,doubleheatingMaxPower):time(t),light(&time,lightMaxPower),heating(&time,heatingMaxPower){}private:Timetime;//Note:stack-all

c++ - 在指针上同时使用前缀和后缀时出现奇怪的输出

给出下面的代码charbuf[]="asfsf";char*a=buf;++*a++;cout我希望结果是“s”的下一个字符“t”,但结果仍然是“s”。为什么?为什么++*a++和不一样*a++;++*a;cout这真的是++i++的重复问题吗?我知道++i++是未定义的行为,会导致编译错误,但++*i++实际上可以运行。我的情况也是未定义的行为吗? 最佳答案 根据语言语法,运算符关联为:++(*a++)注意:结合性并不意味着运算顺序。*a++求值为左值,指定a最初指向的位置,具有修改a的副作用。到目前为止一切正常。将prefix-

c++ - 解释指针的这种情况

我正在学习指针,但我迷失在这段代码中:templateinlineTexport(constchar*dll,constchar*name){return(T)((void*(*)(constchar*,constchar*))GetProcAddress(GetModuleHandleA(dll),name));}更确切地说,我不明白它对void指针进行一些奇怪的转换的部分。更确切的问题:*(*)有什么作用,什么时候可以使用它? 最佳答案 (void*(*)(constchar*,constchar*)表示您正在将以下函数转换为返

c++ - 两个不同的继承指针地址如何相等?

看完C++:Comparingpointersofbaseandderivedclasses,我认为这肯定行不通。当我执行这个时,c_as_b和&c的打印地址不同,那么为什么这个打印“似乎可以安全地比较同一层次结构中的指针”?除了可能导致true的打印地址之外,还比较了什么?您能否举一个类似的小例子,其中==结果为false?#includeusingnamespacestd;structA{std::strings;};structB{inti;};structC:A,B{doubled;};intmain(){Cc;B*c_as_b=&c;A*c_as_a=&c;cout示例输出:

C++:将指针设置为 nullptr 与将其初始化为新变量类型之间的区别

我正在学习C++,我知道“new”关键字用于将内存中的地址分配给指针。而且我认为在使用“nullptr”时会初始化一个指向任何内容的指针。那是对的吗?引用示例://usingnullptrint*x=nullptr;//thisisjustapointerthatpointstonothingand//willneedtobeinitializedwithanaddressbeforeit//itcanbeused.Correct?//usingnewint*x=newint;//thisisbasicallygivingxanaddressinmemory.Willthe//addr