草庐IT

virtual-copy

全部标签

c++ - 初学者 c++ : virtual functions in a base class

我正在编写一些代码,其中我定义了以下基类。classChorus{public://Destructorvirtual~Chorus();//callbackfunctionvirtualintcallback(void*outputBuffer,void*notUsed,unsignedintnBufferFrames,doublestreamTime,RtAudioStreamStatusstatus,void*userData);virtualvoidinitializeDelayBuffer(void);virtualvoiddestroyDelayBuffer(void);}

C++ 继承 : does lack of virtual destructor lead to memory leak?

这个问题在这里已经有了答案:Possiblememoryleakwithoutavirtualdestructor?(3个答案)关闭6年前。我对自己经常问自己的一个问题有疑问,是这样的情况:两个类,没有虚析构函数classBase{intmyInt;};classDerived:publicBase{intmyIntDerived;};intmain(){Base*base=newDerived;Derived*derived=newDerived;deletebase;deletederived;}第一个delete导致内存泄漏而第二个delete没问题,这样说对吗?

c++ - 这是一个有效的 Copy Ctor 吗?

请问是不是下面的拷贝构造函数有问题?classA{private:intm;public:A(Aa){m=a.m}} 最佳答案 两件事:复制构造函数必须将引用作为参数,否则它们是无限递归的(事实上语言不允许你声明这样的构造函数)它不做默认复制构造函数不做的任何事情,但做得很糟糕-您应该尽可能在复制构造函数中使用初始化列表。如果默认的复制构造器可以满足您的需求,请不要试图自己编写版本-您可能只会弄错,并且需要维护它。 关于c++-这是一个有效的CopyCtor吗?,我们在StackOver

C++ 将 memcpy 转换为 std::copy

我想用“std::copy”替换我的“memcpy”,但我找不到传递参数的正确方法。我的旧memcpy代码是memcpy(&uFeatures.Features[0],&((char*)(m_pData))[iBytePos],iByteCount);我用std::copy尝试了各种方法,但都没有用。有人能帮忙吗? 最佳答案 从你的语法来看,它似乎是这样的。(假设Features[0]是char*,如果不是你需要转换(检查评论))std::copy(&uFeatures.Features[0],&uFeatures.Features

c++ - std::copy 的限制是否比 std::memcpy 更宽松?

与regardtothe问题copyvs.memcpyvsmemmove(这里的信息非常好,顺便说一句。),我一直在阅读,在我看来,这不像口语中所说的,例如cppreference注意:memcpy已更改为memmove,因为采用了此引用。--NotesInpractice,implementationsofstd::copyavoidmultipleassignmentsandusebulkcopyfunctionssuchasstd::memcpyifthevaluetypeisTriviallyCopyable--std::copy(也不是std::copy_backward)不

c++ - 我应该从 Boost::filesystem::copy 得到什么错误代码

我正在尝试使用带有system::error_code参数的boost::filesystem::copy_file将文件复制到目标位置,因为我不想抛出异常。如果同名文件已经存在,该函数接受一个参数是否应该失败,这是我想要的行为。来自http://www.boost.org/doc/libs/1_46_1/libs/filesystem/v3/doc/reference.html#copy_file:Effects:Ifoption==copy_option::fail_if_exists&&exists(to),anerrorisreported.但是,我找不到我应该期待的错误代码。

c++ - CUDA 推力 : copy from device to device

我使用标准CUDAmalloc在CUDA中分配了一个内存数组,并将其传递给函数,如下所示:voidMyClass::run(uchar4*input_data)我还有一个类成员,它是一个推力device_ptr声明为:thrust::device_ptrdata=thrust::device_malloc这里的num_pts是数组中值的个数,input_data指针保证是num_pts长。现在,我想将输入数组复制到thrust_device_ptr中。我看过推力文档,其中很多都在谈论从设备复制到主机内存,反之亦然。我想知道在推力上执行此设备到设备复制的最佳性能最佳方式是什么,还是我应该

c++ - CMake : softlink resource ( such as GLSL shaders ) or copy each complilation

使用CMake将资源从源目录复制到构建目录的最简单方法是file(COPY${CMAKE_CURRENT_SOURCE_DIR}/resourcesDESTINATION${CMAKE_CURRENT_BINARY_DIR})但是,这仅当我调用cmake时才会更新构建目录中的资源。我需要每次调用make来更新资源。例如现在我开发了一些GLSL着色器。我需要同时更改C++代码和GLSL代码,并且我需要在我的IDE中每次点击compile或run时一切都同步(我将CodeBlocks与CMake生成的项目文件一起使用)简单的解决方案是使从源目录到构建目录的软链接(softlink)。但我不

c++ - 海湾合作委员会 : C++11 inline object initialization (using "this") does not work when there is a virtual inheritance in hierarchy

当在初始化中使用此指针并且在层次结构中存在虚拟继承时,C++11内联对象初始化不起作用(在GCC中)。这可能是GCC的错误吗(因为它在CLang中工作)?还是C++11标准本身的差距?示例(可以在here中尝试),当使用GCC编译以下代码时:FieldIndexm_inB{"inB",this};不会被执行。但它会在使用CLang编译时执行。变通方法:从FieldIndexContainer派生A作为虚拟#include#include#includeusingnamespacestd;classFieldIndexContainer{public:classFieldIndex{pu

c++ - 为第二个范围内的重复项设置差异,替代 remove_copy

我有两个数组或vector,比如说:intfirst[]={0,0,1,1,2,2,3,3,3};intsecond[]={1,3};我想去掉第一组中的1s和3s,set_difference只能去掉这些值的第一次出现,但这不是我想要的。我是否应该通过迭代第二个范围并每次从第一个集合中删除一个条目来使用remove_copy来执行此操作。在C++中执行此操作的最佳方法是什么? 最佳答案 写一个专门的set_difference:templateOutputIteratorset_difference_any(InputIterato