草庐IT

link-delete

全部标签

c++ - VS2015 : LNK2019 error when linking with Muiload. 库

当包含muiload.h并与muiload.lib链接并在Visual中调用LoadMUILibrary时,我正在试验下一个错误工作室2015:Muiload.lib(muiload.obj):errorLNK2019:unresolvedexternalsymbol__vsnwprintfreferencedinfunction"long__stdcallStringVPrintfWorkerW(unsignedshort*,unsignedint,unsignedint*,unsignedshortconst*,char*)"(?StringVPrintfWorkerW@@YGJP

C++初阶:C/C++内存管理、new与delete详解

之前结束了类与对象:今天进行下面部分内容的学习文章目录1.C/C++内存分布2.C语言中动态内存管理方式:malloc/calloc/realloc/free3.C++动态内存管理方式3.1new/delete操作内置类型3.2new和delete操作自定义类型4.operatornew与operatordelete函数5.new和delete的实现原理5.1内置类型5.2自定义类型6.定位new表达式(placement-new)7.知识点梳理malloc/free和new/delete的区别1.C/C++内存分布具体说明:栈又叫堆栈–非静态局部变量/函数参数/返回值等等,栈是向下增长的。栈

c++ - C++中的delete和调用析构函数有什么区别

如标题所述,这是我的代码:classFoo{public:Foo(intcharSize){str=newchar[charSize];}~Foo(){delete[]str;}private:char*str;};对于这门课,两者之间的区别是什么:intmain(){Foo*foo=newFoo(10);deletefoo;return0;}和intmain(){Foo*foo=newFoo(10);foo->~Foo();return0;} 最佳答案 调用析构函数会释放对象拥有的资源,但不会释放分配给对象本身的内存。第二个代码片

c++ - libtool link - 便利库的全局状态初始化

我的设置不起作用,我不知道我在这里做错了什么-我正在尝试将一个项目从手工制作的Makefile转换为autotools,并且我认为我已经正确设置了大部分项目,因为应用程序及其所有便利库都正确构建和链接,但是全局状态初始化程序存在一些问题便利图书馆。一些库在代码中遵循这样的模式://inglobalscopeofsomemodule.cppnamespace{boolregistered=ModuleShare::registerModule("SomeModule");}这段代码连同实际的模块源代码,使用libtool编译成一个方便的库//libsomethingMakefile.am

c++ - 错误 C2280 : attempting to reference a deleted function (atomic<int>)

我有一个classA带有成员变量_atomicVar类型std::atomic.#includeclassA{public:A();~A();private:std::atomic_atomicVar;};如果我构建项目,我会收到以下错误:errorC2280:'std::atomic::atomic(conststd::atomic&)':attemptingtoreferenceadeletedfunction我主要是一名C#开发人员,所以我还不了解C++的每个细节(还)。我不知道我在哪里使用atomic的复制代码.我还尝试初始化_atomicVar:std::atomic_ato

c++ - Linux 上的 ICC : link to OpenMP

使用英特尔C++编译器链接到OpenMP的步骤是什么?英特尔编译器是否附带其自己的OpenMP库,还是应该链接到libgom? 最佳答案 它显然带有自己的实现。只要使用-openmp标志进行编译,就不需要指定额外的库。$icc-openmpt.c$ldd./a.out...libiomp5.so=>/opt/intel/Compiler/11.1/072/lib/intel64/libiomp5.so(0x00007fd8e7ac6000)... 关于c++-Linux上的ICC:lin

c++ - 我如何在共享内存中使用运算符 `new` 和 `delete`?

我想使用共享内存在多​​个程序之间共享一些对象。我在thissite找到了示例.它没有任何对象分配,只是直接寻址,但我想在共享内存中创建结构或类。 最佳答案 因为内存已经分配好,你想使用placementnew:void*ptr=shmat(shmid,0,0);//HandleerrorsMyClass*x=new(ptr)MyClass;然后,MyClass的新实例将在ptr指向的内存中构造。当不需要该对象时,您必须手动调用析构函数(不释放内存)。ptr->MyClass::~MyClass();

c++ - delete[] 是否释放整个内存块?

考虑以下几点:char*msg=newchar[20];msg[4]='\0';delete[]msg;delete[]msg是否释放了分配给msg的所有20个字符,还是仅释放了\0之前的那些字符?如果它只释放到\0,我怎样才能强制它删除整个内存块? 最佳答案 您问题中的原始代码具有未定义的行为,因为您将delete与new[]一起使用。我注意到您已通过将delete替换为delete[]来修复它:delete[]msg;这是正确的,并且会释放所有由new[]分配的内存。没有“删除到\0”或任何其他此类“部分”删除的概念。只能删除分

c++ - 为什么要使用 new 和 delete?

我是C++的新手,我想知道为什么我还要费心使用new和delete?它可能会导致问题(内存泄漏),我不明白为什么我不应该在没有new运算符的情况下只初始化一个变量。有人可以向我解释吗?很难用谷歌搜索这个具体问题。 最佳答案 出于历史和效率原因,C++(和C)memorymanagement是明确的和手动的。有时,您可能会在callstack上分配(例如,通过使用VLAs或alloca(3))。然而,这并不总是可能的,因为堆栈大小有限(取决于平台,几千字节或几兆字节)。内存需求并不总是FIFO或LIFO.确实发生了您需要分配内存的情况

c++ - deleted 指针指向什么?

int*a=nullptr;//NULLbeforeC++11a=newint(1);deletea;a现在指向什么?它指向nullptr还是指向它在被删除之前指向的地址? 最佳答案 其他一些答案错误地说“值不会改变”。但是确实如此:删除前有效,删除后无效;这是一个变化。此外,值的表示也可能发生变化。例如,实现可以将a设置为null,或者调试器将识别的某种模式,以帮助检测变量的无效使用。 关于c++-deleted指针指向什么?,我们在StackOverflow上找到一个类似的问题: