草庐IT

Ctrl-Alt-Delete

全部标签

c++ - C++ 标准中哪里说::delete 可以更改左值?

我遇到了我的第一个编译器,它更改了传递给::delete的左值,但没有将左值清零。以下是正确的:Foo*p=newFoo();Foo*q=p;assert(p!=0);assert(p==q);::deletep;assert(p!=q);assert(p!=0);请注意,删除操作后p不为零,它已从旧值改变。一位同事告诉我,根据他使用一些大型机C++编译器将p更改为0xFFFFFFFF以及将p更改为0的其他编译器的经验,这并不罕见。在C++标准中哪里说允许编译器这样做?通过StackOverflow搜索,我发现了这个问题:Whydoesn’tdeletesetthepointertoN

c++ - 在 Direct3D (DirectX) 应用程序中禁用 alt-enter

我正在阅读Introductionto3DGameProgrammingwithDirectX10学习一些DirectX,我正在尝试做建议的练习(第4章,对于那些拥有这本书的人)。一个练习要求使用IDXGIFactory::MakeWindowAssociation禁用Alt+Enter功能(切换全屏模式).但是无论如何它都会切换全屏模式,我不明白为什么。这是我的代码:HR(D3D10CreateDevice(0,//defaultadaptermd3dDriverType,0,//nosoftwaredevicecreateDeviceFlags,D3D10_SDK_VERSION,

c++ - 如果我为一个类写new和delete运算符,我是否必须写所有它们的重载?

C++引用页列出了globalnewoperators的8种特定于类的重载。其中有四个是为2017版的C++添加的。类特定的分配函数void*T::operatornew(std::size_tcount);void*T::operatornew[](std::size_tcount);void*T::operatornew(std::size_tcount,std::align_val_tal);//(sinceC++17)void*T::operatornew[](std::size_tcount,std::align_val_tal);//(sinceC++17)特定于类别的展示

c++ - 发送到应用程序的 CTRL-C 的单元测试

我正在开发一个处理CTRL-C的应用程序。我正在生成一个信号处理程序来正常关闭线程和其他资源。我想在我的应用程序可能存在的不同场景中测试CTRL-C。我知道如何为被测进程设置那些,但我需要一种方法(在运行测试套件的代码中)来检查是否达到该条件以准确调用CTRL-C.我在Linux中工作,我想在CPPUNIT的帮助下自动运行我的测试。在我的每个CTRL-C测试中,我开始这个过程,然后我发送CTRL-C使用kill具有进程PID的函数。我正在使用共享内存;一旦测试的应用程序达到我感兴趣的条件或我想发送CTRL-C的点,我就将标记或状态写入共享内存。同时,在不同进程中运行的测试套件代码不断轮

C++:如果我重载 new 运算符,我是否也必须重载 delete 运算符?

我正在阅读关于SO和answers中的一个问题,它被提到为:Ifnounambiguousmatchingdeallocationfunctioncanbefound,propagatingtheexceptiondoesnotcausetheobject’smemorytobefreed.因此,如果我只是重载我的new运算符而不是delete运算符,是否会创建和调用任何默认的delete运算符;或者,我是否还必须显式编写delete运算符。 最佳答案 这意味着如果你用额外的参数重载operatornew,而不是用额外的参数重载相应

c++ - 如何在多线程程序中定位 Valgrind 报告的 free/delete 不匹配?

这是Valgring报告:==14546==Thread5:==14546==Invalidfree()/delete/delete[]==14546==at0x490555D:free(vg_replace_malloc.c:235)==14546==by0x3BF7EFAA8F:free_mem(in/lib64/tls/libc-2.3.4.so)==14546==by0x3BF7EFA581:__libc_freeres(in/lib64/tls/libc-2.3.4.so)==14546==by0x4802676:_vgw_freeres(vg_preloaded.c:62)

C++ 语法 : default and delete modifiers

今天我偶然发现了这样一个代码片段:classA{A()=default;A(constA&)=delete;...}我从未见过delete或default关键字。它们是C++11标准的一部分吗?它们的用途是什么? 最佳答案 现在可以默认或删除特殊成员函数。已删除的成员函数仍然参与重载决议,但如果它被选中,则程序格式错误并且编译停止并提供有用的诊断。这是编写不可复制类之类内容的正确方法,并且用户会收到正确的错误消息。默认成员函数“做它应该做的”,例如默认的默认构造函数默认初始化所有基类和成员,并且主体为空;默认复制构造函数复制每个基对

【C++】:内存管理:C++内存分布 || C++中动态内存管理(new || delete)

📭1.C/C++内存分布【说明】🃏1.栈又叫堆栈–非静态局部变量/函数参数/返回值等等,栈是向下增长的🃏2.内存映射段是高效的I/O映射方式,用于装载一个共享的动态内存库。用户可使用系统接口创建共享共享内存,做进程间通信。(Linux课程如果没学到这块,现在只需要了解一下)🃏3.堆用于程序运行时动态内存分配,堆是可以上增长的。🃏4.数据段–存储全局数据和静态数据。🃏5.代码段–可执行的代码/只读常量我们先来看下面的一段代码和相关问题intglobalVar=1;staticintstaticGlobalVar=1;voidTest(){staticintstaticVar=1;intlocal

c++ - 析构函数中是否需要 delete ?

我有以下代码,我想知道这里是否需要deleteb?我的操作系统会自动清除分配的内存区域吗?classA{B*b;A(){b=newB();}~A(){deleteb;}};非常感谢。 最佳答案 是的,您必须删除您拥有的new创建的每个对象。在这种情况下,看起来classA拥有classB的那个实例,并负责调用delete。使用智能指针来管理classB实例生命周期会更好。另请注意,您必须在classA中实现或禁止赋值运算符和复制构造函数,以防止浅复制对象,这会给您带来很多麻烦。 关于c+

c++ - 为什么在 C++ 中有 delete[]?

为什么会有delete[]?根据我的理解,它对数组的行为有所不同。然而,为什么它真的存在?C中只有free而没有free_array。同样在语法上,deletevar和delete[]var之间的唯一区别是[]没有参数(我不是在告诉数组的长度)。那么为什么delete[]真的存在呢?我知道有人会说你可以重载delete和delete[](至少我认为这是可能的)但可以说我们没有重载它。它为什么存在? 最佳答案 通常,对于非POD类,delete[]表达式必须在编译时无法确定的可变数量的类实例上调用析构函数。编译器通常必须实现一些运行时